forked from J3rome/CLEAR-AQA-Dataset-Generator
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgenerate_CLEAR_dataset.sh
executable file
·189 lines (163 loc) · 7.59 KB
/
generate_CLEAR_dataset.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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
#!/usr/bin/env bash
# Will stop the script on first error
set -e
# Parameters :
## scene_max_lengths: [50000]
## question_insts_per_scene: [4]
## spectrogram_window_lengths: [1024]
## spectrogram_window_overlap: [0.5]
## Base scene arguments : arguments/base_scene_generation.args
## Base question arguments : arguments/base_question_generation.args
## Base spectrogram arguments : arguments/base_audio_generation.args
# Scene Preparation
mkdir -p output/CLEAR_50k
mkdir -p output/CLEAR_50k/log
# Scene Generation
if [[ ! -e output/CLEAR_50k/scenes ]]; then
if [[ -e output/CLEAR_50k.tar.gz ]]; then
echo "Untaring 'CLEAR_50k.tar.gz'"
pigz -dc output/CLEAR_50k.tar.gz | tar xf - -C output
else
set -x
python generate_scenes_definition.py @arguments/base_scene_generation.args --output_folder output --nb_scene 50000 --output_version_nb CLEAR_50k > output/CLEAR_50k/log/scene_generation.log &
{ set +x; } 2>/dev/null
fi
sleep 0.5
fi
PROCESS_0_PID=$!
wait ${PROCESS_0_PID}
# Question Preparation
mkdir -p output/CLEAR_50k_4_inst
mkdir -p output/CLEAR_50k_4_inst/log
ln -sf ../CLEAR_50k/attributes.json output/CLEAR_50k_4_inst/attributes.json
[[ -e output/CLEAR_50k/scenes ]] && ln -snf ../CLEAR_50k/scenes output/CLEAR_50k_4_inst/scenes
# Question Generation
if [[ ! -e output/CLEAR_50k_4_inst/questions/CLEAR_val_questions.json && ! -e output/CLEAR_50k_4_inst/questions/TMP_val ]]; then
if [[ -e output/CLEAR_50k_4_inst.tar.gz ]]; then
echo "Untaring 'CLEAR_50k_4_inst.tar.gz'"
pigz -dc output/CLEAR_50k_4_inst.tar.gz | tar xf - -C output
else
set -x
python generate_questions.py @arguments/base_question_generation.args --output_folder output --templates_per_scene 4 --output_version_nb CLEAR_50k_4_inst --set_type val > output/CLEAR_50k_4_inst/log/question_generation_val.log &
{ set +x; } 2>/dev/null
fi
sleep 0.5
fi
PROCESS_0_PID=$!
if [[ ! -e output/CLEAR_50k_4_inst/questions/CLEAR_test_questions.json && ! -e output/CLEAR_50k_4_inst/questions/TMP_test ]]; then
if [[ -e output/CLEAR_50k_4_inst.tar.gz ]]; then
echo "Untaring 'CLEAR_50k_4_inst.tar.gz'"
pigz -dc output/CLEAR_50k_4_inst.tar.gz | tar xf - -C output
else
set -x
python generate_questions.py @arguments/base_question_generation.args --output_folder output --templates_per_scene 4 --output_version_nb CLEAR_50k_4_inst --set_type test > output/CLEAR_50k_4_inst/log/question_generation_test.log &
{ set +x; } 2>/dev/null
fi
sleep 0.5
fi
PROCESS_1_PID=$!
if [[ ! -e output/CLEAR_50k_4_inst/questions/CLEAR_train_questions.json && ! -e output/CLEAR_50k_4_inst/questions/TMP_train ]]; then
if [[ -e output/CLEAR_50k_4_inst.tar.gz ]]; then
echo "Untaring 'CLEAR_50k_4_inst.tar.gz'"
pigz -dc output/CLEAR_50k_4_inst.tar.gz | tar xf - -C output
else
set -x
python generate_questions.py @arguments/base_question_generation.args --output_folder output --templates_per_scene 4 --output_version_nb CLEAR_50k_4_inst --set_type train > output/CLEAR_50k_4_inst/log/question_generation_train.log &
{ set +x; } 2>/dev/null
fi
sleep 0.5
fi
PROCESS_2_PID=$!
wait ${PROCESS_0_PID} ${PROCESS_1_PID} ${PROCESS_2_PID}
# Question Consolidation
if [[ ! -e output/CLEAR_50k_4_inst/questions/CLEAR_train_questions.json ]]; then
if [[ -e output/CLEAR_50k_4_inst.tar.gz ]]; then
echo "Untaring 'CLEAR_50k_4_inst.tar.gz'"
pigz -dc output/CLEAR_50k_4_inst.tar.gz | tar xf - -C output
else
set -x
python ./scripts/consolidate_questions.py --output_folder output --tmp_folder_prefix TMP_ --remove_tmp --output_version_nb CLEAR_50k_4_inst --set_type train &
{ set +x; } 2>/dev/null
fi
sleep 0.5
fi
PROCESS_0_PID=$!
if [[ ! -e output/CLEAR_50k_4_inst/questions/CLEAR_val_questions.json ]]; then
if [[ -e output/CLEAR_50k_4_inst.tar.gz ]]; then
echo "Untaring 'CLEAR_50k_4_inst.tar.gz'"
pigz -dc output/CLEAR_50k_4_inst.tar.gz | tar xf - -C output
else
set -x
python ./scripts/consolidate_questions.py --output_folder output --tmp_folder_prefix TMP_ --remove_tmp --output_version_nb CLEAR_50k_4_inst --set_type val &
{ set +x; } 2>/dev/null
fi
sleep 0.5
fi
PROCESS_1_PID=$!
if [[ ! -e output/CLEAR_50k_4_inst/questions/CLEAR_test_questions.json ]]; then
if [[ -e output/CLEAR_50k_4_inst.tar.gz ]]; then
echo "Untaring 'CLEAR_50k_4_inst.tar.gz'"
pigz -dc output/CLEAR_50k_4_inst.tar.gz | tar xf - -C output
else
set -x
python ./scripts/consolidate_questions.py --output_folder output --tmp_folder_prefix TMP_ --remove_tmp --output_version_nb CLEAR_50k_4_inst --set_type test &
{ set +x; } 2>/dev/null
fi
sleep 0.5
fi
PROCESS_2_PID=$!
wait ${PROCESS_0_PID} ${PROCESS_1_PID} ${PROCESS_2_PID}
# Spectrogram FFT Preparation
mkdir -p output/CLEAR_50k_1024_win_50_overlap
mkdir -p output/CLEAR_50k_1024_win_50_overlap/preprocessed
mkdir -p output/CLEAR_50k_1024_win_50_overlap/log
ln -sf ../CLEAR_50k/attributes.json output/CLEAR_50k_1024_win_50_overlap/attributes.json
[[ -e output/CLEAR_50k/scenes ]] && ln -snf ../CLEAR_50k/scenes output/CLEAR_50k_1024_win_50_overlap/scenes
# Spectrogram Generation
if [[ ! -e output/CLEAR_50k_1024_win_50_overlap/images/val ]]; then
if [[ -e output/CLEAR_50k_1024_win_50_overlap.tar.gz ]]; then
echo "Untaring 'CLEAR_50k_1024_win_50_overlap.tar.gz'"
pigz -dc output/CLEAR_50k_1024_win_50_overlap.tar.gz | tar xf - -C output
else
set -x
python produce_scenes_audio.py @arguments/base_audio_generation.args --output_folder output --output_version_nb CLEAR_50k_1024_win_50_overlap --spectrogram_window_length 1024 --spectrogram_window_overlap 512 --set_type val --nb_process 2 > output/CLEAR_50k_1024_win_50_overlap/log/spectrogram_fft_val.log &
{ set +x; } 2>/dev/null
fi
sleep 0.5
fi
PROCESS_0_PID=$!
if [[ ! -e output/CLEAR_50k_1024_win_50_overlap/images/test ]]; then
if [[ -e output/CLEAR_50k_1024_win_50_overlap.tar.gz ]]; then
echo "Untaring 'CLEAR_50k_1024_win_50_overlap.tar.gz'"
pigz -dc output/CLEAR_50k_1024_win_50_overlap.tar.gz | tar xf - -C output
else
set -x
python produce_scenes_audio.py @arguments/base_audio_generation.args --output_folder output --output_version_nb CLEAR_50k_1024_win_50_overlap --spectrogram_window_length 1024 --spectrogram_window_overlap 512 --set_type test --nb_process 2 > output/CLEAR_50k_1024_win_50_overlap/log/spectrogram_fft_test.log &
{ set +x; } 2>/dev/null
fi
sleep 0.5
fi
PROCESS_2_PID=$!
wait ${PROCESS_0_PID} ${PROCESS_2_PID}
if [[ ! -e output/CLEAR_50k_1024_win_50_overlap/images/train ]]; then
if [[ -e output/CLEAR_50k_1024_win_50_overlap.tar.gz ]]; then
echo "Untaring 'CLEAR_50k_1024_win_50_overlap.tar.gz'"
pigz -dc output/CLEAR_50k_1024_win_50_overlap.tar.gz | tar xf - -C output
else
set -x
python produce_scenes_audio.py @arguments/base_audio_generation.args --output_folder output --output_version_nb CLEAR_50k_1024_win_50_overlap --spectrogram_window_length 1024 --spectrogram_window_overlap 512 --set_type train --nb_process 4 > output/CLEAR_50k_1024_win_50_overlap/log/spectrogram_fft_train.log &
{ set +x; } 2>/dev/null
fi
sleep 0.5
fi
PROCESS_0_PID=$!
wait ${PROCESS_0_PID}
# Linking versions together
mkdir -p output/CLEAR_50k_4_inst_1024_win_50_overlap
ln -sf ../CLEAR_50k/attributes.json output/CLEAR_50k_4_inst_1024_win_50_overlap/attributes.json
ln -snf ../CLEAR_50k/scenes output/CLEAR_50k_4_inst_1024_win_50_overlap/scenes
ln -snf ../CLEAR_50k_4_inst/questions output/CLEAR_50k_4_inst_1024_win_50_overlap/questions
[[ -e output/CLEAR_50k_1024_win_50_overlap/images ]] && ln -snf ../CLEAR_50k_1024_win_50_overlap/images output/CLEAR_50k_4_inst_1024_win_50_overlap/images
[[ -e output/CLEAR_50k_1024_win_50_overlap/audio ]] && ln -snf ../CLEAR_50k_1024_win_50_overlap/audio output/CLEAR_50k_4_inst_1024_win_50_overlap/audio
[[ -e output/CLEAR_50k_1024_win_50_overlap/preprocessed ]] && ln -snf ../CLEAR_50k_1024_win_50_overlap/preprocessed output/CLEAR_50k_4_inst_1024_win_50_overlap/preprocessed
echo "All Done !"