2020-12-20 13:15:07 +08:00
|
|
|
# Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
|
2020-12-18 19:51:55 +08:00
|
|
|
import os
|
|
|
|
import pickle
|
|
|
|
import argparse
|
|
|
|
from pathlib import Path
|
|
|
|
|
2021-05-13 17:49:50 +08:00
|
|
|
import tqdm
|
|
|
|
import numpy as np
|
2021-08-26 11:14:24 +08:00
|
|
|
from parakeet.audio import AudioProcessor
|
|
|
|
from parakeet.audio import LogMagnitude
|
|
|
|
from parakeet.datasets import LJSpeechMetaData
|
|
|
|
from parakeet.frontend import English
|
2020-12-18 19:51:55 +08:00
|
|
|
|
|
|
|
from config import get_cfg_defaults
|
|
|
|
|
2020-12-20 13:15:07 +08:00
|
|
|
|
2020-12-18 19:51:55 +08:00
|
|
|
def create_dataset(config, source_path, target_path, verbose=False):
|
|
|
|
# create output dir
|
|
|
|
target_path = Path(target_path).expanduser()
|
|
|
|
mel_path = target_path / "mel"
|
|
|
|
os.makedirs(mel_path, exist_ok=True)
|
|
|
|
|
|
|
|
meta_data = LJSpeechMetaData(source_path)
|
|
|
|
frontend = English()
|
|
|
|
processor = AudioProcessor(
|
|
|
|
sample_rate=config.data.sample_rate,
|
|
|
|
n_fft=config.data.n_fft,
|
2021-05-18 17:53:09 +08:00
|
|
|
n_mels=config.data.n_mels,
|
2020-12-20 13:15:07 +08:00
|
|
|
win_length=config.data.win_length,
|
2020-12-18 19:51:55 +08:00
|
|
|
hop_length=config.data.hop_length,
|
2021-05-13 17:49:50 +08:00
|
|
|
fmax=config.data.fmax,
|
|
|
|
fmin=config.data.fmin)
|
2020-12-18 19:51:55 +08:00
|
|
|
normalizer = LogMagnitude()
|
2020-12-20 13:15:07 +08:00
|
|
|
|
2020-12-18 19:51:55 +08:00
|
|
|
records = []
|
|
|
|
for (fname, text, _) in tqdm.tqdm(meta_data):
|
|
|
|
wav = processor.read_wav(fname)
|
|
|
|
mel = processor.mel_spectrogram(wav)
|
|
|
|
mel = normalizer.transform(mel)
|
|
|
|
phonemes = frontend.phoneticize(text)
|
|
|
|
ids = frontend.numericalize(phonemes)
|
|
|
|
mel_name = os.path.splitext(os.path.basename(fname))[0]
|
|
|
|
|
|
|
|
# save mel spectrogram
|
|
|
|
records.append((mel_name, text, phonemes, ids))
|
|
|
|
np.save(mel_path / mel_name, mel)
|
|
|
|
if verbose:
|
|
|
|
print("save mel spectrograms into {}".format(mel_path))
|
2020-12-20 13:15:07 +08:00
|
|
|
|
2020-12-18 19:51:55 +08:00
|
|
|
# save meta data as pickle archive
|
|
|
|
with open(target_path / "metadata.pkl", 'wb') as f:
|
|
|
|
pickle.dump(records, f)
|
|
|
|
if verbose:
|
2021-08-17 15:29:30 +08:00
|
|
|
print("saved metadata into {}".format(target_path / "metadata.pkl"))
|
2020-12-18 19:51:55 +08:00
|
|
|
|
|
|
|
# also save meta data into text format for inspection
|
|
|
|
with open(target_path / "metadata.txt", 'wt') as f:
|
|
|
|
for mel_name, text, phonemes, _ in records:
|
|
|
|
phoneme_str = "|".join(phonemes)
|
|
|
|
f.write("{}\t{}\t{}\n".format(mel_name, text, phoneme_str))
|
|
|
|
if verbose:
|
2021-08-17 15:29:30 +08:00
|
|
|
print("saved metadata into {}".format(target_path / "metadata.txt"))
|
2020-12-20 13:15:07 +08:00
|
|
|
|
2020-12-18 19:51:55 +08:00
|
|
|
print("Done.")
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
parser = argparse.ArgumentParser(description="create dataset")
|
2020-12-20 13:15:07 +08:00
|
|
|
parser.add_argument(
|
|
|
|
"--config",
|
|
|
|
type=str,
|
|
|
|
metavar="FILE",
|
|
|
|
help="extra config to overwrite the default config")
|
|
|
|
parser.add_argument(
|
|
|
|
"--input", type=str, help="path of the ljspeech dataset")
|
|
|
|
parser.add_argument(
|
|
|
|
"--output", type=str, help="path to save output dataset")
|
|
|
|
parser.add_argument(
|
|
|
|
"--opts",
|
|
|
|
nargs=argparse.REMAINDER,
|
2020-12-18 19:51:55 +08:00
|
|
|
help="options to overwrite --config file and the default config, passing in KEY VALUE pairs"
|
|
|
|
)
|
2020-12-20 13:15:07 +08:00
|
|
|
parser.add_argument(
|
|
|
|
"-v", "--verbose", action="store_true", help="print msg")
|
|
|
|
|
2020-12-18 19:51:55 +08:00
|
|
|
config = get_cfg_defaults()
|
|
|
|
args = parser.parse_args()
|
|
|
|
if args.config:
|
|
|
|
config.merge_from_file(args.config)
|
|
|
|
if args.opts:
|
|
|
|
config.merge_from_list(args.opts)
|
|
|
|
config.freeze()
|
|
|
|
print(config.data)
|
|
|
|
|
|
|
|
create_dataset(config, args.input, args.output, args.verbose)
|