-
Notifications
You must be signed in to change notification settings - Fork 37
/
Copy pathpreprocess.py
36 lines (32 loc) · 2.03 KB
/
preprocess.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
import argparse
import shutil
import yaml
import os
from preprocessor.preprocessor import Preprocessor
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument("config", type=str, help="path to preprocess.yaml")
args = parser.parse_args()
config = yaml.load(open(args.config, "r"), Loader=yaml.FullLoader)
if "LibriTTS" in config["dataset"]:
if config["subsets"]["train"] == "train-clean":
config["subsets"]["train"] = ["train-clean-100", "train-clean-360"]
elif config["subsets"]["train"] == "train-all":
config["subsets"]["train"] = ["train-clean-100", "train-clean-360", "train-other-500"]
preprocessor = Preprocessor(config)
preprocessor.build_from_path()
if "LibriTTS" in config["dataset"]:
if config["subsets"]["train"] == ["train-clean-100", "train-clean-360"]:
with open(os.path.join(config["path"]["preprocessed_path"], "train-clean.txt"), 'wb') as out_file:
with open(os.path.join(config["path"]["preprocessed_path"], "train-clean-100.txt"), 'rb') as in_file:
shutil.copyfileobj(in_file, out_file)
with open(os.path.join(config["path"]["preprocessed_path"], "train-clean-360.txt"), 'rb') as in_file:
shutil.copyfileobj(in_file, out_file)
elif config["subsets"]["train"] == ["train-clean-100", "train-clean-360", "train-other-500"]:
with open(os.path.join(config["path"]["preprocessed_path"], "train-all.txt"), 'wb') as out_file:
with open(os.path.join(config["path"]["preprocessed_path"], "train-clean-100.txt"), 'rb') as in_file:
shutil.copyfileobj(in_file, out_file)
with open(os.path.join(config["path"]["preprocessed_path"], "train-clean-360.txt"), 'rb') as in_file:
shutil.copyfileobj(in_file, out_file)
with open(os.path.join(config["path"]["preprocessed_path"], "train-other-500.txt"), 'rb') as in_file:
shutil.copyfileobj(in_file, out_file)