Note
Click here to download the full example code
Audio Datasets¶
Author: Moto Hira
torchaudio provides easy access to common, publicly accessible
datasets. Please refer to the official documentation for the list of
available datasets.
import torch
import torchaudio
print(torch.__version__)
print(torchaudio.__version__)
2.3.0
2.3.0
import os
import IPython
import matplotlib.pyplot as plt
_SAMPLE_DIR = "_assets"
YESNO_DATASET_PATH = os.path.join(_SAMPLE_DIR, "yes_no")
os.makedirs(YESNO_DATASET_PATH, exist_ok=True)
def plot_specgram(waveform, sample_rate, title="Spectrogram"):
    waveform = waveform.numpy()
    figure, ax = plt.subplots()
    ax.specgram(waveform[0], Fs=sample_rate)
    figure.suptitle(title)
    figure.tight_layout()
Here, we show how to use the
torchaudio.datasets.YESNO dataset.
dataset = torchaudio.datasets.YESNO(YESNO_DATASET_PATH, download=True)
  0%|          | 0.00/4.49M [00:00<?, ?B/s]
  3%|2         | 128k/4.49M [00:00<00:08, 525kB/s]
 11%|#1        | 512k/4.49M [00:00<00:02, 1.42MB/s]
 28%|##7       | 1.25M/4.49M [00:00<00:01, 3.27MB/s]
 67%|######6   | 3.00M/4.49M [00:00<00:00, 6.79MB/s]
100%|##########| 4.49M/4.49M [00:00<00:00, 6.82MB/s]
i = 1
waveform, sample_rate, label = dataset[i]
plot_specgram(waveform, sample_rate, title=f"Sample {i}: {label}")
IPython.display.Audio(waveform, rate=sample_rate)
![Sample 1: [0, 0, 0, 1, 0, 0, 0, 1]](https://pytorch.org/audio/2.3.0/_images/sphx_glr_audio_datasets_tutorial_001.png) 
i = 3
waveform, sample_rate, label = dataset[i]
plot_specgram(waveform, sample_rate, title=f"Sample {i}: {label}")
IPython.display.Audio(waveform, rate=sample_rate)
![Sample 3: [0, 0, 1, 0, 0, 0, 1, 0]](https://pytorch.org/audio/2.3.0/_images/sphx_glr_audio_datasets_tutorial_002.png) 
i = 5
waveform, sample_rate, label = dataset[i]
plot_specgram(waveform, sample_rate, title=f"Sample {i}: {label}")
IPython.display.Audio(waveform, rate=sample_rate)
![Sample 5: [0, 0, 1, 0, 0, 1, 1, 1]](https://pytorch.org/audio/2.3.0/_images/sphx_glr_audio_datasets_tutorial_003.png) 
Total running time of the script: ( 0 minutes 1.749 seconds)