-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsubmit_vocoder.sh
87 lines (75 loc) · 2.78 KB
/
submit_vocoder.sh
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
#!/usr/bin/env bash
# Copyright (c) Meta Platforms, Inc. and affiliates.
# All rights reserved.
#
# This source code is licensed under the license found in the
# LICENSE file in the root directory of this source tree.
#
# Reference (https://github.com/kan-bayashi/ParallelWaveGAN/)
#SBATCH -p xxx
#SBATCH -N 1 # number of nodes
#SBATCH -n 1 # number of nodes
#SBATCH -c 16 # number of cores
#SBATCH --mem 64g
#SBATCH -t 7-00:00
#SBATCH --job-name=vctk_AD_v0
#SBATCH --output=/mnt/home/slurmlogs/vctk/vocoder/AudioDec_v0_symAD_vctk_48000_hop300_clean.out # STDOUT
#SBATCH --error=/mnt/home/slurmlogs/vctk/vocoder/AudioDec_v0_symAD_vctk_48000_hop300_clean.err # STDERR
#SBATCH --gres=gpu:1
### useage ###
# (training from scratch): sbatch/bash submit_vocoder.sh --stage 0 (--tag_name xxx)
# (resume training): sbatch/bash submit_vocoder.sh --stage 1 (--tag_name xxx --resumepoint xxx)
# (testing): sbatch/bash submit_vocoder.sh --stage 2 (--tag_name xxx --encoder_checkpoint xxx --decoder_checkpoint xxx --subset xxx --subset_num xxx)
### VCTK ###
autoencoder=autoencoder/symAD_vctk_48000_hop300
tag_name="vocoder/AudioDec_v0_symAD_vctk_48000_hop300_clean"
#tag_name="vocoder/AudioDec_v1_symAD_vctk_48000_hop300_clean"
#tag_name="vocoder/AudioDec_v2_symAD_vctk_48000_hop300_clean"
#autoencoder=autoencoder/symADuniv_vctk_48000_hop300
#tag_name="vocoder/AudioDec_v3_symADuniv_vctk_48000_hop300_clean"
### LibriTTS ###
#autoencoder=autoencoder/symAD_libritts_24000_hop300
#tag_name="vocoder/AudioDec_v1_symAD_libritts_24000_hop300_clean"
stage=0
# stage 0: training from scratch
# stage 1: resuming training from previous saved checkpoint
# stage 2: testing
resumepoint=200000
encoder_checkpoint=200000
#encoder_checkpoint=500000
decoder_checkpoint=500000
exp=exp # Folder of models
disable_cudnn=False
subset=test
subset_num=-1
. ./parse_options.sh || exit 1;
config_name="config/${tag_name}.yaml"
echo "Configuration file="$config_name
# stage 0
if echo ${stage} | grep -q 0; then
echo "Training from scratch"
python codecTrain.py \
-c ${config_name} \
--tag ${tag_name} \
--exp_root ${exp} \
--disable_cudnn ${disable_cudnn}
fi
# stage 1
if echo ${stage} | grep -q 1; then
resume=exp/${tag_name}/checkpoint-${resumepoint}steps.pkl
echo "Resume from ${resume}"
python codecTrain.py \
-c ${config_name} \
--tag ${tag_name} --resume ${resume} \
--disable_cudnn ${disable_cudnn}
fi
# stage 2
if echo ${stage} | grep -q 2; then
echo "Testing"
python codecTest.py \
--subset ${subset} \
--subset_num ${subset_num} \
--encoder exp/${autoencoder}/checkpoint-${encoder_checkpoint}steps.pkl \
--decoder exp/${tag_name}/checkpoint-${decoder_checkpoint}steps.pkl \
--output_dir output/${tag_name}
fi