vggishFeatures
The vggishFeatures
function has been removed. Use
vggishEmbeddings
instead. For more information, see Version History.
Description
returns VGGish feature embeddings over time for the audio input embeddings
= vggishFeatures(audioIn
,fs
)audioIn
with sample rate fs
. Columns of the input are treated as individual
channels.
specifies options using one or more embeddings
= vggishFeatures(audioIn
,fs
,Name,Value
)Name,Value
arguments. For example,
embeddings = vggishFeatures(audioIn,fs,'ApplyPCA',true)
applies a
principal component analysis (PCA) transformation to the audio embeddings.
This function requires both Audio Toolbox™ and Deep Learning Toolbox™.
Examples
Download vggishFeatures
Functionality
Download and unzip the Audio Toolbox™ model for VGGish.
Type vggishFeatures
at the command line. If the Audio Toolbox model for VGGish is not installed, then the function provides a link to the location of the network weights. To download the model, click the link. Unzip the file to a location on the MATLAB path.
Alternatively, execute the following commands to download and unzip the VGGish model to your temporary directory.
downloadFolder = fullfile(tempdir,'VGGishDownload'); loc = websave(downloadFolder,'https://ssd.mathworks.com/supportfiles/audio/vggish.zip'); VGGishLocation = tempdir; unzip(loc,VGGishLocation) addpath(fullfile(VGGishLocation,'vggish'))
Extract VGGish Embeddings
Read in an audio file.
[audioIn,fs] = audioread('MainStreetOne-16-16-mono-12secs.wav');
Call the vggishFeatures
function with the audio and sample rate to extract VGGish feature embeddings from the audio.
featureVectors = vggishFeatures(audioIn,fs);
The vggishFeatures
function returns a matrix of 128-element feature vectors over time.
[numHops,numElementsPerHop,numChannels] = size(featureVectors)
numHops = 23
numElementsPerHop = 128
numChannels = 1
Increase Time Resolution of VGGish Features
Create a 10-second pink noise signal and then extract VGGish features. The vggishFeatures
function extracts features from mel spectrograms with 50% overlap.
fs = 16e3;
dur = 10;
audioIn = pinknoise(dur*fs,1,'single');
features = vggishFeatures(audioIn,fs);
Plot the VGGish features over time.
surf(features,'EdgeColor','none') view([30 65]) axis tight xlabel('Feature Index') ylabel('Frame') xlabel('Feature Value') title('VGGish Features')
To increase the resolution of VGGish features over time, specify the percent overlap between mel spectrograms. Plot the results.
overlapPercentage = 75; features = vggishFeatures(audioIn,fs,'OverlapPercentage',overlapPercentage); surf(features,'EdgeColor','none') view([30 65]) axis tight xlabel('Feature Index') ylabel('Frame') zlabel('Feature Value') title('VGGish Features')
Apply Principal Component Analysis to VGGish Embeddings
Read in an audio file, listen to it, and then extract VGGish features from the audio.
[audioIn,fs] = audioread('Counting-16-44p1-mono-15secs.wav');
sound(audioIn,fs)
features = vggishFeatures(audioIn,fs);
Visualize the VGGish features over time. Many of the individual features are zero-valued and contain no useful information.
surf(features,'EdgeColor','none') view([90,-90]) axis tight xlabel('Feature Index') ylabel('Frame Index') title('VGGish Features')
You can apply principal component analysis (PCA) to map the feature vectors into a space that emphasizes variation between the embeddings. Call the vggishFeatures
function again and specify ApplyPCA
as true
. Visualize the VGGish features after PCA.
features = vggishFeatures(audioIn,fs,'ApplyPCA',true); surf(features,'EdgeColor','none') view([90,-90]) axis tight xlabel('Feature Index') ylabel('Frame Index') title('VGGish Features + PCA')
Use VGGish Embeddings for Deep Learning
Download and unzip the air compressor data set. This data set consists of recordings from air compressors in a healthy state or in one of seven faulty states.
url = 'https://www.mathworks.com/supportfiles/audio/AirCompressorDataset/AirCompressorDataset.zip'; downloadFolder = fullfile(tempdir,'aircompressordataset'); datasetLocation = tempdir; if ~exist(fullfile(tempdir,'AirCompressorDataSet'),'dir') loc = websave(downloadFolder,url); unzip(loc,fullfile(tempdir,'AirCompressorDataSet')) end
Create an audioDatastore
object to manage the data and split it into training and validation sets.
ads = audioDatastore(downloadFolder,'IncludeSubfolders',true,'LabelSource','foldernames'); [adsTrain,adsValidation] = splitEachLabel(ads,0.8,0.2);
Read an audio file from the datastore and save the sample rate for later use. Reset the datastore to return the read pointer to the beginning of the data set. Listen to the audio signal and plot the signal in the time domain.
[x,fileInfo] = read(adsTrain); fs = fileInfo.SampleRate; reset(adsTrain) sound(x,fs) figure t = (0:size(x,1)-1)/fs; plot(t,x) xlabel('Time (s)') title('State = ' + string(fileInfo.Label)) axis tight
Extract VGGish features from the training and validation sets. Transpose the features so that time is along rows.
trainFeatures = cell(1,numel(adsTrain.Files)); for idx = 1:numel(adsTrain.Files) [audioIn,fileInfo] = read(adsTrain); features = vggishFeatures(audioIn,fileInfo.SampleRate); trainFeatures{idx} = features'; end validationFeatures = cell(1,numel(adsValidation.Files)); for idx = 1:numel(adsValidation.Files) [audioIn,fileInfo] = read(adsValidation); features = vggishFeatures(audioIn,fileInfo.SampleRate); validationFeatures{idx} = features'; end
Define a Long Short-Term Memory Neural Networks (Deep Learning Toolbox) network.
layers = [ sequenceInputLayer(128) lstmLayer(100,'OutputMode','last') fullyConnectedLayer(8) softmaxLayer classificationLayer];
To define training options, use trainingOptions
(Deep Learning Toolbox).
miniBatchSize = 64; validationFrequency = 5*floor(numel(trainFeatures)/miniBatchSize); options = trainingOptions("adam", ... "MaxEpochs",12, ... "MiniBatchSize",miniBatchSize, ... "Plots","training-progress", ... "Shuffle","every-epoch", ... "LearnRateSchedule","piecewise", ... "LearnRateDropPeriod",6, ... "LearnRateDropFactor",0.1, ... "ValidationData",{validationFeatures,adsValidation.Labels}, ... "ValidationFrequency",validationFrequency, ... 'Verbose',false);
To train the network, use trainNetwork
(Deep Learning Toolbox).
net = trainNetwork(trainFeatures,adsTrain.Labels,layers,options)
net = SeriesNetwork with properties: Layers: [5×1 nnet.cnn.layer.Layer] InputNames: {'sequenceinput'} OutputNames: {'classoutput'}
Visualize the confusion matrix for the validation set.
predictedClass = classify(net,validationFeatures); confusionchart(adsValidation.Labels,predictedClass)
Use VGGish Embeddings for Machine Learning
Download and unzip the air compressor data set [1]. This data set consists of recordings from air compressors in a healthy state or in one of seven faulty states.
url = 'https://www.mathworks.com/supportfiles/audio/AirCompressorDataset/AirCompressorDataset.zip'; downloadFolder = fullfile(tempdir,'aircompressordataset'); datasetLocation = tempdir; if ~exist(fullfile(tempdir,'AirCompressorDataSet'),'dir') loc = websave(downloadFolder,url); unzip(loc,fullfile(tempdir,'AirCompressorDataSet')) end
Create an audioDatastore
object to manage the data and split it into training and validation sets.
ads = audioDatastore(downloadFolder,'IncludeSubfolders',true,'LabelSource','foldernames');
In this example, you classify signals as either healthy or faulty. Combine all of the faulty labels into a single label. Split the datastore into training and validation sets.
labels = ads.Labels; labels(labels~=categorical("Healthy")) = categorical("Faulty"); ads.Labels = removecats(labels); [adsTrain,adsValidation] = splitEachLabel(ads,0.8,0.2);
Extract VGGish features from the training set. Each audio file corresponds to multiple VGGish features. Replicate the labels so that they are in one-to-one correspondence with the features.
trainFeatures = []; trainLabels = []; for idx = 1:numel(adsTrain.Files) [audioIn,fileInfo] = read(adsTrain); features = vggishFeatures(audioIn,fileInfo.SampleRate); trainFeatures = [trainFeatures;features]; trainLabels = [trainLabels;repelem(fileInfo.Label,size(features,1))']; end
Train a cubic support vector machine (SVM) using fitcsvm
(Statistics and Machine Learning Toolbox). To explore other classifiers and their performances, use Classification Learner (Statistics and Machine Learning Toolbox).
faultDetector = fitcsvm( ... trainFeatures, ... trainLabels, ... 'KernelFunction','polynomial', ... 'PolynomialOrder',3, ... 'KernelScale','auto', ... 'BoxConstraint',1, ... 'Standardize',true, ... 'ClassNames',categories(trainLabels));
For each file in the validation set:
Extract VGGish features.
For each VGGish feature vector in a file, use the trained classifier to predict whether the machine is healthy or faulty.
Take the mode of the predictions for each file.
predictions = []; for idx = 1:numel(adsValidation.Files) [audioIn,fileInfo] = read(adsValidation); features = vggishFeatures(audioIn,fileInfo.SampleRate); predictionsPerFile = categorical(predict(faultDetector,features)); predictions = [predictions;mode(predictionsPerFile)]; end
Use confusionchart
(Statistics and Machine Learning Toolbox) to display the performance of the classifier.
accuracy = sum(predictions==adsValidation.Labels)/numel(adsValidation.Labels);
cc = confusionchart(predictions,adsValidation.Labels);
cc.Title = sprintf('Accuracy = %0.2f %',accuracy*100);
References
[1] Verma, Nishchal K., Rahul Kumar Sevakula, Sonal Dixit, and Al Salour. 2016. “Intelligent Condition Based Monitoring Using Acoustic Signals for Air Compressors.” IEEE Transactions on Reliability 65 (1): 291–309. https://doi.org/10.1109/TR.2015.2459684.
Input Arguments
audioIn
— Input signal
column vector | matrix
Input signal, specified as a column vector or matrix. If you specify a matrix,
vggishFeatures
treats the columns of the matrix as individual
audio channels.
The duration of audioIn
must be equal to or greater than 0.975
seconds.
Data Types: single
| double
fs
— Sample rate (Hz)
positive scalar
Sample rate of the input signal in Hz, specified as a positive scalar.
Data Types: single
| double
Name-Value Arguments
Specify optional pairs of arguments as
Name1=Value1,...,NameN=ValueN
, where Name
is
the argument name and Value
is the corresponding value.
Name-value arguments must appear after other arguments, but the order of the
pairs does not matter.
Before R2021a, use commas to separate each name and value, and enclose
Name
in quotes.
Example: 'OverlapPercentage',75
OverlapPercentage
— Percentage overlap between consecutive audio frames
50
(default) | scalar in the range [0,100)
Percentage overlap between consecutive audio frames, specified as a scalar in the range [0,100).
Data Types: single
| double
ApplyPCA
— Flag to apply PCA transformation to audio embeddings
false
(default) | true
Flag to apply PCA transformation to audio embeddings, specified as either
true
or false
.
Data Types: logical
Output Arguments
embeddings
— Compact representation of audio data
L-by-128-by-N array
Compact representation of audio data, returned as an L-by-128-by-N array, where:
L –– Represents the number of frames the audio signal is partitioned into. This is determined by the
OverlapPercentage
.128 –– Represents the audio embedding length.
N –– Represents the number of channels.
Algorithms
The vggishFeatures
function uses VGGish to extract feature embeddings
from audio. The vggishFeatures
function preprocesses the audio so that it
is in the format required by VGGish and optionally postprocesses the embeddings.
Preprocess
Resample
audioIn
to 16 kHz and cast to single precision.Compute a one-sided short time Fourier transform using a 25 ms periodic Hann window with a 10 ms hop, and a 512-point DFT. The audio is now represented by a 257-by-L array, where 257 is the number of bins in the one-sided spectra, and L depends on the length of the input.
Convert the complex spectral values to magnitude and discard phase information.
Pass the one-sided magnitude spectrum through a 64-band mel-spaced filter bank, then sum the magnitudes in each band. The audio is now represented by a single 64-by-L mel spectrogram.
Convert the mel spectrogram to a log scale.
Buffer the mel spectrogram into overlapped segments consisting of 96 spectra each. The audio is now represented by a 96-by-64-by-1-by-K array, where 96 is the number of spectra in the individual mel spectrograms, 64 is the number of mel bands, and the spectrograms are spaced along the fourth dimension for compatibility with the VGGish model. The number of mel spectrograms, K, depends on the input length and
OverlapPercentage
.
Feature Extraction
Pass the 96-by-64-by-1-by-K array of mel spectrograms through VGGish to return a K-by-128 matrix. The output from VGGish are the feature embeddings corresponding to each 0.975 s frame of audio data.
Postprocess
If ApplyPCA
is set to true
, the feature
embeddings are postprocessed to match the postprocessing of the released AudioSet
embeddings. The VGGish model was released with a precomputed principal component analysis
(PCA) matrix and mean vector to apply a PCA transformation and whitening during inference.
The postprocessing includes applying PCA, whitening, and quantization.
Subtract the precomputed 1-by-128 PCA mean vector from the K-by-128 feature matrix, and then premultiply the result by the precomputed 128-by-128 PCA matrix.
Clip the transformed and whitened embeddings to between –2 and 2, then quantize the result to values that can be represented by
uint8
.
References
[1] Gemmeke, Jort F., Daniel P. W. Ellis, Dylan Freedman, Aren Jansen, Wade Lawrence, R. Channing Moore, Manoj Plakal, and Marvin Ritter. 2017. “Audio Set: An Ontology and Human-Labeled Dataset for Audio Events.” In 2017 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP), 776–80. New Orleans, LA: IEEE. https://doi.org/10.1109/ICASSP.2017.7952261.
[2] Hershey, Shawn, Sourish Chaudhuri, Daniel P. W. Ellis, Jort F. Gemmeke, Aren Jansen, R. Channing Moore, Manoj Plakal, et al. 2017. “CNN Architectures for Large-Scale Audio Classification.” In 2017 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP), 131–35. New Orleans, LA: IEEE. https://doi.org/10.1109/ICASSP.2017.7952132.
Extended Capabilities
GPU Arrays
Accelerate code by running on a graphics processing unit (GPU) using Parallel Computing Toolbox™.
This function fully supports GPU arrays. For more information, see Run MATLAB Functions on a GPU (Parallel Computing Toolbox).
Version History
Introduced in R2020bR2024b: Errors
The vggishFeatures
function has been removed. Use vggishEmbeddings
instead.
R2024a: Warns
The vggishFeatures
function issues a warning that it will be
removed in a future release.
R2022a: To be removed
The vggishFeatures
function will be removed in a future release.
Existing calls to vggishFeatures
continue to run without
warning.
See Also
Apps
Blocks
Functions
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: United States.
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
Asia Pacific
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)