-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathdataset.py
49 lines (31 loc) · 1.2 KB
/
dataset.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
import os
import glob
import random
from collections import namedtuple
AudioVisualEntry = namedtuple('AudioVisualEntry', ['speaker_id', 'audio_path', 'video_path'])
class AudioVisualDataset:
def __init__(self, base_path):
self._base_path = base_path
def subset(self, speaker_ids, max_files=None, shuffle=False):
entries = []
for speaker_id in speaker_ids:
audio_paths = glob.glob(os.path.join(self._base_path, speaker_id, "audio", "*.wav"))
for audio_path in audio_paths:
entry = AudioVisualEntry(speaker_id, audio_path, AudioVisualDataset.__audio_to_video_path(audio_path))
entries.append(entry)
if shuffle:
random.shuffle(entries)
return entries[:max_files]
def list_speakers(self):
return os.listdir(self._base_path)
@staticmethod
def __audio_to_video_path(audio_path):
return glob.glob(os.path.splitext(audio_path.replace("audio", "video"))[0] + ".*")[0]
class AudioDataset:
def __init__(self, base_paths):
self._base_paths = base_paths
def subset(self, max_files=None, shuffle=False):
audio_file_paths = [os.path.join(d, f) for d in self._base_paths for f in os.listdir(d)]
if shuffle:
random.shuffle(audio_file_paths)
return audio_file_paths[:max_files]