Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
DeepSpeech
提交
9944fec3
D
DeepSpeech
项目概览
PaddlePaddle
/
DeepSpeech
大约 2 年 前同步成功
通知
210
Star
8425
Fork
1598
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
245
列表
看板
标记
里程碑
合并请求
3
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
DeepSpeech
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
245
Issue
245
列表
看板
标记
里程碑
合并请求
3
合并请求
3
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
9944fec3
编写于
4月 01, 2022
作者:
X
xiongxinlei
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
convert rirs noise to csv file
上级
ec24a169
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
469 addition
and
13 deletion
+469
-13
examples/voxceleb/sv0/conf/ecapa_tdnn.yaml
examples/voxceleb/sv0/conf/ecapa_tdnn.yaml
+1
-0
examples/voxceleb/sv0/local/data.sh
examples/voxceleb/sv0/local/data.sh
+52
-13
examples/voxceleb/sv0/local/make_rirs_noise_csv_dataset_from_json.py
...xceleb/sv0/local/make_rirs_noise_csv_dataset_from_json.py
+154
-0
examples/voxceleb/sv0/local/make_vox_csv_dataset_from_json.py
...ples/voxceleb/sv0/local/make_vox_csv_dataset_from_json.py
+262
-0
未找到文件。
examples/voxceleb/sv0/conf/ecapa_tdnn.yaml
浏览文件 @
9944fec3
...
@@ -8,6 +8,7 @@ batch_size: 16
...
@@ -8,6 +8,7 @@ batch_size: 16
num_workers
:
2
num_workers
:
2
num_speakers
:
7205
# 1211 vox1, 5994 vox2, 7205 vox1+2, test speakers: 41
num_speakers
:
7205
# 1211 vox1, 5994 vox2, 7205 vox1+2, test speakers: 41
shuffle
:
True
shuffle
:
True
skip_prep
:
False
split_ratio
:
0.9
split_ratio
:
0.9
chunk_duration
:
3.0
# seconds
chunk_duration
:
3.0
# seconds
random_chunk
:
True
random_chunk
:
True
...
...
examples/voxceleb/sv0/local/data.sh
浏览文件 @
9944fec3
...
@@ -12,8 +12,8 @@
...
@@ -12,8 +12,8 @@
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# See the License for the specific language governing permissions and
# limitations under the License.
# limitations under the License.
stage
=
5
stage
=
7
stop_stage
=
5
stop_stage
=
100
.
${
MAIN_ROOT
}
/utils/parse_options.sh
||
exit
-1
;
.
${
MAIN_ROOT
}
/utils/parse_options.sh
||
exit
-1
;
...
@@ -38,13 +38,14 @@ mkdir -p ${TARGET_DIR}
...
@@ -38,13 +38,14 @@ mkdir -p ${TARGET_DIR}
if
[
${
stage
}
-le
1
]
&&
[
${
stop_stage
}
-ge
1
]
;
then
if
[
${
stage
}
-le
1
]
&&
[
${
stop_stage
}
-ge
1
]
;
then
# download data, generate manifests
# download data, generate manifests
# we will generate the manifest.{dev, test} file in ${dir}/vox1/ directory
echo
"Start to download vox1 dataset and generate the manifest files "
echo
"Start to download vox1 dataset and generate the manifest files "
python3
${
TARGET_DIR
}
/voxceleb/voxceleb1.py
\
python3
${
TARGET_DIR
}
/voxceleb/voxceleb1.py
\
--manifest_prefix
=
"
data
/vox1/manifest"
\
--manifest_prefix
=
"
${
dir
}
/vox1/manifest"
\
--target_dir
=
"
${
TARGET_DIR
}
/voxceleb/vox1/"
--target_dir
=
"
${
TARGET_DIR
}
/voxceleb/vox1/"
if
[
$?
-ne
0
]
;
then
if
[
$?
-ne
0
]
;
then
echo
"Prepare voxceleb failed. Terminated."
echo
"Prepare voxceleb
1
failed. Terminated."
exit
1
exit
1
fi
fi
...
@@ -58,7 +59,7 @@ if [ ${stage} -le 2 ] && [ ${stop_stage} -ge 2 ]; then
...
@@ -58,7 +59,7 @@ if [ ${stage} -le 2 ] && [ ${stop_stage} -ge 2 ]; then
--target_dir
=
"
${
TARGET_DIR
}
/voxceleb/vox2/"
--target_dir
=
"
${
TARGET_DIR
}
/voxceleb/vox2/"
if
[
$?
-ne
0
]
;
then
if
[
$?
-ne
0
]
;
then
echo
"
Prepare voxceleb
failed. Terminated."
echo
"
Download voxceleb2 dataset
failed. Terminated."
exit
1
exit
1
fi
fi
...
@@ -66,32 +67,41 @@ fi
...
@@ -66,32 +67,41 @@ fi
if
[
${
stage
}
-le
3
]
&&
[
${
stop_stage
}
-ge
3
]
;
then
if
[
${
stage
}
-le
3
]
&&
[
${
stop_stage
}
-ge
3
]
;
then
# convert the m4a to wav
# convert the m4a to wav
# and we will not delete the original m4a file
echo
"start to convert the m4a to wav"
echo
"start to convert the m4a to wav"
bash
local
/convert.sh
${
TARGET_DIR
}
/voxceleb/vox2/test/
||
exit
1
;
bash
local
/convert.sh
${
TARGET_DIR
}
/voxceleb/vox2/test/
||
exit
1
;
if
[
$?
-ne
0
]
;
then
echo
"Convert voxceleb2 dataset from m4a to wav failed. Terminated."
exit
1
fi
echo
"m4a convert to wav operation finished"
echo
"m4a convert to wav operation finished"
fi
fi
if
[
${
stage
}
-le
4
]
&&
[
${
stop_stage
}
-ge
4
]
;
then
if
[
${
stage
}
-le
4
]
&&
[
${
stop_stage
}
-ge
4
]
;
then
# generate the vox2 manifest file
# generate the vox2 manifest file from wav file
# we will generate the manifest.vox2 in ${dir}/vox2 directory
# because we use all the vox2 dataset to train, so collect all the vox2 data in one file
echo
"start generate the vox2 manifest files"
echo
"start generate the vox2 manifest files"
python3
${
TARGET_DIR
}
/voxceleb/voxceleb2.py
\
python3
${
TARGET_DIR
}
/voxceleb/voxceleb2.py
\
--generate
\
--generate
\
--manifest_prefix
=
"
data
/vox2/manifest"
\
--manifest_prefix
=
"
${
dir
}
/vox2/manifest"
\
--target_dir
=
"
${
TARGET_DIR
}
/voxceleb/vox2/"
--target_dir
=
"
${
TARGET_DIR
}
/voxceleb/vox2/"
if
[
$?
-ne
0
]
;
then
if
[
$?
-ne
0
]
;
then
echo
"Prepare voxceleb failed. Terminated."
echo
"Prepare voxceleb
2 dataset
failed. Terminated."
exit
1
exit
1
fi
fi
fi
fi
if
[
${
stage
}
-le
5
]
&&
[
${
stop_stage
}
-ge
5
]
;
then
if
[
${
stage
}
-le
5
]
&&
[
${
stop_stage
}
-ge
5
]
;
then
# generate the vox2 manifest file
# generate the vox csv file
# Currently, our training system use csv file for dataset
echo
"convert the json format to csv format to be compatible with training process"
echo
"convert the json format to csv format to be compatible with training process"
python3
local
/make_csv_dataset_from_json.py
\
python3
local
/make_csv_dataset_from_json.py
\
--train
"
data
/vox1/manifest.dev"
\
--train
"
${
dir
}
/vox1/manifest.dev"
\
--test
"
data
/vox1/manifest.test"
\
--test
"
${
dir
}
/vox1/manifest.test"
\
--target_dir
"
data
/vox/"
\
--target_dir
"
${
dir
}
/vox/"
\
--config
${
conf_path
}
--config
${
conf_path
}
if
[
$?
-ne
0
]
;
then
if
[
$?
-ne
0
]
;
then
...
@@ -100,6 +110,35 @@ if [ ${stage} -le 5 ] && [ ${stop_stage} -ge 5 ]; then
...
@@ -100,6 +110,35 @@ if [ ${stage} -le 5 ] && [ ${stop_stage} -ge 5 ]; then
fi
fi
fi
fi
if
[
${
stage
}
-le
6
]
&&
[
${
stop_stage
}
-ge
6
]
;
then
# generate the open rir noise manifest file
echo
"generate the open rir noise manifest file"
python3
${
TARGET_DIR
}
/rir_noise/rir_noise.py
\
--manifest_prefix
=
"
${
dir
}
/rir_noise/manifest"
\
--target_dir
=
"
${
TARGET_DIR
}
/rir_noise/"
if
[
$?
-ne
0
]
;
then
echo
"Prepare rir_noise failed. Terminated."
exit
1
fi
fi
if
[
${
stage
}
-le
7
]
&&
[
${
stop_stage
}
-ge
7
]
;
then
# generate the open rir noise manifest file
echo
"generate the open rir noise csv file"
python3
local
/make_rirs_noise_csv_dataset_from_json.py
\
--noise_dir
=
"
${
TARGET_DIR
}
/rir_noise/"
\
--data_dir
=
"
${
dir
}
/rir_noise/"
\
--config
${
conf_path
}
if
[
$?
-ne
0
]
;
then
echo
"Prepare rir_noise failed. Terminated."
exit
1
fi
fi
...
...
examples/voxceleb/sv0/local/make_rirs_noise_csv_dataset_from_json.py
0 → 100644
浏览文件 @
9944fec3
# Copyright (c) 2022 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.
"""
Convert the PaddleSpeech jsonline format data to csv format data in voxceleb experiment.
Currently, Speaker Identificaton Training process use csv format.
"""
import
argparse
import
csv
import
os
from
typing
import
List
import
paddle
import
tqdm
from
yacs.config
import
CfgNode
from
paddlespeech.s2t.utils.log
import
Log
from
paddlespeech.vector.training.seeding
import
seed_everything
logger
=
Log
(
__name__
).
getlog
()
from
paddleaudio
import
load
as
load_audio
from
paddleaudio
import
save
as
save_wav
def
get_chunks
(
seg_dur
,
audio_id
,
audio_duration
):
num_chunks
=
int
(
audio_duration
/
seg_dur
)
# all in milliseconds
chunk_lst
=
[
audio_id
+
"_"
+
str
(
i
*
seg_dur
)
+
"_"
+
str
(
i
*
seg_dur
+
seg_dur
)
for
i
in
range
(
num_chunks
)
]
return
chunk_lst
def
get_audio_info
(
wav_file
:
str
,
split_chunks
:
bool
,
base_path
:
str
,
chunk_duration
:
float
=
3.0
)
->
List
[
List
[
str
]]:
waveform
,
sr
=
load_audio
(
wav_file
)
audio_id
=
wav_file
.
split
(
"/rir_noise/"
)[
-
1
].
split
(
"."
)[
0
]
audio_duration
=
waveform
.
shape
[
0
]
/
sr
ret
=
[]
if
split_chunks
and
audio_duration
>
chunk_duration
:
# Split into pieces of self.chunk_duration seconds.
uniq_chunks_list
=
get_chunks
(
chunk_duration
,
audio_id
,
audio_duration
)
for
idx
,
chunk
in
enumerate
(
uniq_chunks_list
):
s
,
e
=
chunk
.
split
(
"_"
)[
-
2
:]
# Timestamps of start and end
start_sample
=
int
(
float
(
s
)
*
sr
)
end_sample
=
int
(
float
(
e
)
*
sr
)
new_wav_file
=
os
.
path
.
join
(
base_path
,
audio_id
+
f
'_chunk_
{
idx
+
1
:
02
}
.wav'
)
save_wav
(
waveform
[
start_sample
:
end_sample
],
sr
,
new_wav_file
)
# id, duration, new_wav
ret
.
append
([
chunk
,
chunk_duration
,
new_wav_file
])
else
:
# Keep whole audio.
ret
.
append
([
audio_id
,
audio_duration
,
wav_file
])
return
ret
def
generate_csv
(
wav_files
,
output_file
:
str
,
base_path
:
str
,
split_chunks
:
bool
=
True
):
print
(
f
'Generating csv:
{
output_file
}
'
)
header
=
[
"id"
,
"duration"
,
"wav"
]
csv_lines
=
[]
for
item
in
tqdm
.
tqdm
(
wav_files
):
csv_lines
.
extend
(
get_audio_info
(
item
,
base_path
=
base_path
,
split_chunks
=
split_chunks
))
if
not
os
.
path
.
exists
(
os
.
path
.
dirname
(
output_file
)):
os
.
makedirs
(
os
.
path
.
dirname
(
output_file
))
with
open
(
output_file
,
mode
=
"w"
)
as
csv_f
:
csv_writer
=
csv
.
writer
(
csv_f
,
delimiter
=
","
,
quotechar
=
'"'
,
quoting
=
csv
.
QUOTE_MINIMAL
)
csv_writer
.
writerow
(
header
)
for
line
in
csv_lines
:
csv_writer
.
writerow
(
line
)
def
prepare_data
(
args
,
config
):
# stage0: set the cpu device,
# all data prepare process will be done in cpu mode
paddle
.
device
.
set_device
(
"cpu"
)
# set the random seed, it is a must for multiprocess training
seed_everything
(
config
.
seed
)
# if external config set the skip_prep flat, we will do nothing
if
config
.
skip_prep
:
return
base_path
=
args
.
noise_dir
wav_path
=
os
.
path
.
join
(
base_path
,
"RIRS_NOISES"
)
logger
.
info
(
f
"base path:
{
base_path
}
"
)
logger
.
info
(
f
"wav path:
{
wav_path
}
"
)
rir_list
=
os
.
path
.
join
(
wav_path
,
"real_rirs_isotropic_noises"
,
"rir_list"
)
rir_files
=
[]
with
open
(
rir_list
,
'r'
)
as
f
:
for
line
in
f
.
readlines
():
rir_file
=
line
.
strip
().
split
(
' '
)[
-
1
]
rir_files
.
append
(
os
.
path
.
join
(
base_path
,
rir_file
))
noise_list
=
os
.
path
.
join
(
wav_path
,
"pointsource_noises"
,
"noise_list"
)
noise_files
=
[]
with
open
(
noise_list
,
'r'
)
as
f
:
for
line
in
f
.
readlines
():
noise_file
=
line
.
strip
().
split
(
' '
)[
-
1
]
noise_files
.
append
(
os
.
path
.
join
(
base_path
,
noise_file
))
csv_path
=
os
.
path
.
join
(
args
.
data_dir
,
'csv'
)
generate_csv
(
rir_files
,
os
.
path
.
join
(
csv_path
,
'rir.csv'
),
base_path
=
base_path
)
generate_csv
(
noise_files
,
os
.
path
.
join
(
csv_path
,
'noise.csv'
),
base_path
=
base_path
)
if
__name__
==
"__main__"
:
parser
=
argparse
.
ArgumentParser
(
description
=
__doc__
)
parser
.
add_argument
(
"--noise_dir"
,
default
=
None
,
required
=
True
,
help
=
"The noise dataset dataset directory."
)
parser
.
add_argument
(
"--data_dir"
,
default
=
None
,
required
=
True
,
help
=
"The target directory stores the csv files"
)
parser
.
add_argument
(
"--config"
,
default
=
None
,
required
=
True
,
type
=
str
,
help
=
"configuration file"
)
args
=
parser
.
parse_args
()
# parse the yaml config file
config
=
CfgNode
(
new_allowed
=
True
)
if
args
.
config
:
config
.
merge_from_file
(
args
.
config
)
# prepare the csv file from jsonlines files
prepare_data
(
args
,
config
)
examples/voxceleb/sv0/local/make_csv_dataset_from_json.py
→
examples/voxceleb/sv0/local/make_
vox_
csv_dataset_from_json.py
浏览文件 @
9944fec3
...
@@ -12,47 +12,66 @@
...
@@ -12,47 +12,66 @@
# See the License for the specific language governing permissions and
# See the License for the specific language governing permissions and
# limitations under the License.
# limitations under the License.
"""
"""
Convert the PaddleSpeech jsonline format
to csv format
Convert the PaddleSpeech jsonline format
data to csv format data in voxceleb experiment.
Currently, Speaker Identificaton Training process
need
csv format.
Currently, Speaker Identificaton Training process
use
csv format.
"""
"""
import
argparse
import
argparse
import
os
import
jsonlines
import
collections
import
json
import
csv
import
csv
from
yacs.config
import
CfgNode
import
json
import
os
import
random
import
paddle
import
tqdm
import
tqdm
from
yacs.config
import
CfgNode
from
paddleaudio
import
load
as
load_audio
from
paddleaudio
import
load
as
load_audio
import
random
from
paddlespeech.s2t.utils.log
import
Log
from
paddlespeech.vector.training.seeding
import
seed_everything
from
paddlespeech.vector.training.seeding
import
seed_everything
# voxceleb meta info for each training utterance segment
logger
=
Log
(
__name__
).
getlog
()
# we extract a segment from a utterance to train
# and the segment' period is between start and stop time point in the original wav file
# each field in the meta means as follows:
# id: the utterance segment name
# duration: utterance segment time
# wav: utterance file path
# start: start point in the original wav file
# stop: stop point in the original wav file
# spk_id: the utterance segment's speaker name
meta_info
=
collections
.
namedtuple
(
'META_INFO'
,
(
'id'
,
'duration'
,
'wav'
,
'start'
,
'stop'
,
'spk_id'
))
def
get_chunks
(
seg_dur
,
audio_id
,
audio_duration
):
def
get_chunks
(
seg_dur
,
audio_id
,
audio_duration
):
"""Get all chunk segments from a utterance
Args:
seg_dur (float): segment chunk duration
audio_id (str): utterance name
audio_duration (float): utterance duration
Returns:
List: all the chunk segments
"""
num_chunks
=
int
(
audio_duration
/
seg_dur
)
# all in milliseconds
num_chunks
=
int
(
audio_duration
/
seg_dur
)
# all in milliseconds
chunk_lst
=
[
chunk_lst
=
[
audio_id
+
"_"
+
str
(
i
*
seg_dur
)
+
"_"
+
str
(
i
*
seg_dur
+
seg_dur
)
audio_id
+
"_"
+
str
(
i
*
seg_dur
)
+
"_"
+
str
(
i
*
seg_dur
+
seg_dur
)
for
i
in
range
(
num_chunks
)
for
i
in
range
(
num_chunks
)
]
]
return
chunk_lst
return
chunk_lst
def
prepare_csv
(
wav_files
,
output_file
,
config
,
split_chunks
=
True
):
def
prepare_csv
(
wav_files
,
output_file
,
config
,
split_chunks
=
True
):
"""Prepare the csv file according the wav files
Args:
dataset_list (list): all the dataset to get the test utterances
verification_file (str): voxceleb1 trial file
"""
if
not
os
.
path
.
exists
(
os
.
path
.
dirname
(
output_file
)):
if
not
os
.
path
.
exists
(
os
.
path
.
dirname
(
output_file
)):
os
.
makedirs
(
os
.
path
.
dirname
(
output_file
))
os
.
makedirs
(
os
.
path
.
dirname
(
output_file
))
csv_lines
=
[]
csv_lines
=
[]
header
=
[
"id"
,
"duration"
,
"wav"
,
"start"
,
"stop"
,
"spk_id"
]
header
=
[
"id"
,
"duration"
,
"wav"
,
"start"
,
"stop"
,
"spk_id"
]
for
item
in
wav_files
:
# voxceleb meta info for each training utterance segment
# we extract a segment from a utterance to train
# and the segment' period is between start and stop time point in the original wav file
# each field in the meta means as follows:
# id: the utterance segment name
# duration: utterance segment time
# wav: utterance file path
# start: start point in the original wav file
# stop: stop point in the original wav file
# spk_id: the utterance segment's speaker name
for
item
in
tqdm
.
tqdm
(
wav_files
,
total
=
len
(
wav_files
)):
item
=
json
.
loads
(
item
.
strip
())
item
=
json
.
loads
(
item
.
strip
())
audio_id
=
item
[
'utt'
].
replace
(
".wav"
,
""
)
audio_id
=
item
[
'utt'
].
replace
(
".wav"
,
""
)
audio_duration
=
item
[
'feat_shape'
][
0
]
audio_duration
=
item
[
'feat_shape'
][
0
]
...
@@ -60,7 +79,8 @@ def prepare_csv(wav_files, output_file, config, split_chunks=True):
...
@@ -60,7 +79,8 @@ def prepare_csv(wav_files, output_file, config, split_chunks=True):
spk_id
=
audio_id
.
split
(
'-'
)[
0
]
spk_id
=
audio_id
.
split
(
'-'
)[
0
]
waveform
,
sr
=
load_audio
(
wav_file
)
waveform
,
sr
=
load_audio
(
wav_file
)
if
split_chunks
:
if
split_chunks
:
uniq_chunks_list
=
get_chunks
(
config
.
chunk_duration
,
audio_id
,
audio_duration
)
uniq_chunks_list
=
get_chunks
(
config
.
chunk_duration
,
audio_id
,
audio_duration
)
for
chunk
in
uniq_chunks_list
:
for
chunk
in
uniq_chunks_list
:
s
,
e
=
chunk
.
split
(
"_"
)[
-
2
:]
# Timestamps of start and end
s
,
e
=
chunk
.
split
(
"_"
)[
-
2
:]
# Timestamps of start and end
start_sample
=
int
(
float
(
s
)
*
sr
)
start_sample
=
int
(
float
(
s
)
*
sr
)
...
@@ -69,19 +89,34 @@ def prepare_csv(wav_files, output_file, config, split_chunks=True):
...
@@ -69,19 +89,34 @@ def prepare_csv(wav_files, output_file, config, split_chunks=True):
csv_lines
.
append
([
csv_lines
.
append
([
chunk
,
audio_duration
,
wav_file
,
start_sample
,
end_sample
,
chunk
,
audio_duration
,
wav_file
,
start_sample
,
end_sample
,
spk_id
spk_id
])
])
else
:
else
:
csv_lines
.
append
([
audio_id
,
audio_duration
,
wav_file
,
0
,
waveform
.
shape
[
0
],
spk_id
])
csv_lines
.
append
([
audio_id
,
audio_duration
,
wav_file
,
0
,
waveform
.
shape
[
0
],
spk_id
])
with
open
(
output_file
,
mode
=
"w"
)
as
csv_f
:
with
open
(
output_file
,
mode
=
"w"
)
as
csv_f
:
csv_writer
=
csv
.
writer
(
csv_f
,
delimiter
=
','
,
quotechar
=
'"'
,
quoting
=
csv
.
QUOTE_MINIMAL
)
csv_writer
=
csv
.
writer
(
csv_f
,
delimiter
=
','
,
quotechar
=
'"'
,
quoting
=
csv
.
QUOTE_MINIMAL
)
csv_writer
.
writerow
(
header
)
csv_writer
.
writerow
(
header
)
for
line
in
csv_lines
:
for
line
in
csv_lines
:
csv_writer
.
writerow
(
line
)
csv_writer
.
writerow
(
line
)
def
get_enroll_test_list
(
filelist
,
verification_file
):
print
(
f
"verification file:
{
verification_file
}
"
)
def
get_enroll_test_list
(
dataset_list
,
verification_file
):
"""Get the enroll and test utterance list from all the voxceleb1 test utterance dataset.
Generally, we get the enroll and test utterances from the verfification file.
The verification file format as follows:
target/nontarget enroll-utt test-utt,
we set 0 as nontarget and 1 as target, eg:
0 a.wav b.wav
1 a.wav a.wav
Args:
dataset_list (list): all the dataset to get the test utterances
verification_file (str): voxceleb1 trial file
"""
logger
.
info
(
f
"verification file:
{
verification_file
}
"
)
enroll_audios
=
set
()
enroll_audios
=
set
()
test_audios
=
set
()
test_audios
=
set
()
with
open
(
verification_file
,
'r'
)
as
f
:
with
open
(
verification_file
,
'r'
)
as
f
:
...
@@ -89,58 +124,112 @@ def get_enroll_test_list(filelist, verification_file):
...
@@ -89,58 +124,112 @@ def get_enroll_test_list(filelist, verification_file):
_
,
enroll_file
,
test_file
=
line
.
strip
().
split
(
' '
)
_
,
enroll_file
,
test_file
=
line
.
strip
().
split
(
' '
)
enroll_audios
.
add
(
'-'
.
join
(
enroll_file
.
split
(
'/'
)))
enroll_audios
.
add
(
'-'
.
join
(
enroll_file
.
split
(
'/'
)))
test_audios
.
add
(
'-'
.
join
(
test_file
.
split
(
'/'
)))
test_audios
.
add
(
'-'
.
join
(
test_file
.
split
(
'/'
)))
enroll_files
=
[]
enroll_files
=
[]
test_files
=
[]
test_files
=
[]
for
item
in
file
list
:
for
dataset
in
dataset_
list
:
with
open
(
item
,
'r'
)
as
f
:
with
open
(
dataset
,
'r'
)
as
f
:
for
line
in
f
:
for
line
in
f
:
audio_id
=
json
.
loads
(
line
.
strip
())[
'utt'
]
audio_id
=
json
.
loads
(
line
.
strip
())[
'utt'
]
if
audio_id
in
enroll_audios
:
if
audio_id
in
enroll_audios
:
enroll_files
.
append
(
line
)
enroll_files
.
append
(
line
)
if
audio_id
in
test_audios
:
if
audio_id
in
test_audios
:
test_files
.
append
(
line
)
test_files
.
append
(
line
)
enroll_files
=
sorted
(
enroll_files
)
enroll_files
=
sorted
(
enroll_files
)
test_files
=
sorted
(
test_files
)
test_files
=
sorted
(
test_files
)
return
enroll_files
,
test_files
return
enroll_files
,
test_files
def
get_train_dev_list
(
filelist
,
target_dir
,
split_ratio
):
def
get_train_dev_list
(
dataset_list
,
target_dir
,
split_ratio
):
"""Get the train and dev utterance list from all the training utterance dataset.
Generally, we use the split_ratio as the train dataset ratio,
and the remaining utterance (ratio is 1 - split_ratio) is the dev dataset
Args:
dataset_list (list): all the dataset to get the all utterances
target_dir (str): the target train and dev directory,
we will create the csv directory to store the {train,dev}.csv file
split_ratio (float): train dataset ratio in all utterance list
"""
logger
.
info
(
"start to get train and dev utt list"
)
if
not
os
.
path
.
exists
(
os
.
path
.
join
(
target_dir
,
"meta"
)):
if
not
os
.
path
.
exists
(
os
.
path
.
join
(
target_dir
,
"meta"
)):
os
.
makedirs
(
os
.
path
.
join
(
target_dir
,
"meta"
))
os
.
makedirs
(
os
.
path
.
join
(
target_dir
,
"meta"
))
audio_files
=
[]
audio_files
=
[]
speakers
=
set
()
speakers
=
set
()
for
item
in
file
list
:
for
dataset
in
dataset_
list
:
with
open
(
item
,
'r'
)
as
f
:
with
open
(
dataset
,
'r'
)
as
f
:
for
line
in
f
:
for
line
in
f
:
spk_id
=
json
.
loads
(
line
.
strip
())[
'utt2spk'
]
spk_id
=
json
.
loads
(
line
.
strip
())[
'utt2spk'
]
speakers
.
add
(
spk_id
)
speakers
.
add
(
spk_id
)
audio_files
.
append
(
line
.
strip
())
audio_files
.
append
(
line
.
strip
())
speakers
=
sorted
(
speakers
)
speakers
=
sorted
(
speakers
)
logger
.
info
(
f
"we get
{
len
(
speakers
)
}
speakers from all the train dataset"
)
with
open
(
os
.
path
.
join
(
target_dir
,
"meta"
,
"spk_id2label.txt"
),
'w'
)
as
f
:
with
open
(
os
.
path
.
join
(
target_dir
,
"meta"
,
"spk_id2label.txt"
),
'w'
)
as
f
:
for
label
,
spk_id
in
enumerate
(
speakers
):
for
label
,
spk_id
in
enumerate
(
speakers
):
f
.
write
(
f
'
{
spk_id
}
{
label
}
\n
'
)
f
.
write
(
f
'
{
spk_id
}
{
label
}
\n
'
)
logger
.
info
(
f
'we store the speakers to
{
os
.
path
.
join
(
target_dir
,
"meta"
,
"spk_id2label.txt"
)
}
'
)
# the split_ratio is for train dataset
# the remaining is for dev dataset
split_idx
=
int
(
split_ratio
*
len
(
audio_files
))
split_idx
=
int
(
split_ratio
*
len
(
audio_files
))
audio_files
=
sorted
(
audio_files
)
random
.
shuffle
(
audio_files
)
random
.
shuffle
(
audio_files
)
train_files
,
dev_files
=
audio_files
[:
split_idx
],
audio_files
[
split_idx
:]
train_files
,
dev_files
=
audio_files
[:
split_idx
],
audio_files
[
split_idx
:]
logger
.
info
(
f
"we get train utterances:
{
len
(
train_files
)
}
, dev utterance:
{
len
(
dev_files
)
}
"
)
return
train_files
,
dev_files
return
train_files
,
dev_files
def
prepare_data
(
args
,
config
):
def
prepare_data
(
args
,
config
):
"""Convert the jsonline format to csv format
paddle
.
set_device
(
"cpu"
)
Args:
args (argparse.Namespace): scripts args
config (CfgNode): yaml configuration content
"""
# stage0: set the cpu device,
# all data prepare process will be done in cpu mode
paddle
.
device
.
set_device
(
"cpu"
)
# set the random seed, it is a must for multiprocess training
seed_everything
(
config
.
seed
)
seed_everything
(
config
.
seed
)
# if external config set the skip_prep flat, we will do nothing
enroll_files
,
test_files
=
get_enroll_test_list
([
args
.
test
],
verification_file
=
config
.
verification_file
)
if
config
.
skip_prep
:
prepare_csv
(
enroll_files
,
os
.
path
.
join
(
args
.
target_dir
,
"csv"
,
"enroll.csv"
),
config
,
split_chunks
=
False
)
return
prepare_csv
(
test_files
,
os
.
path
.
join
(
args
.
target_dir
,
"csv"
,
"test.csv"
),
config
,
split_chunks
=
False
)
# stage 1: prepare the enroll and test csv file
train_files
,
dev_files
=
get_train_dev_list
(
args
.
train
,
target_dir
=
args
.
target_dir
,
split_ratio
=
config
.
split_ratio
)
# And we generate the speaker to label file spk_id2label.txt
prepare_csv
(
train_files
,
os
.
path
.
join
(
args
.
target_dir
,
"csv"
,
"train.csv"
),
config
)
logger
.
info
(
"start to prepare the data csv file"
)
prepare_csv
(
dev_files
,
os
.
path
.
join
(
args
.
target_dir
,
"csv"
,
"dev.csv"
),
config
)
enroll_files
,
test_files
=
get_enroll_test_list
(
[
args
.
test
],
verification_file
=
config
.
verification_file
)
prepare_csv
(
enroll_files
,
os
.
path
.
join
(
args
.
target_dir
,
"csv"
,
"enroll.csv"
),
config
,
split_chunks
=
False
)
prepare_csv
(
test_files
,
os
.
path
.
join
(
args
.
target_dir
,
"csv"
,
"test.csv"
),
config
,
split_chunks
=
False
)
# stage 2: prepare the train and dev csv file
# we get the train dataset ratio as config.split_ratio
# and the remaining is dev dataset
logger
.
info
(
"start to prepare the data csv file"
)
train_files
,
dev_files
=
get_train_dev_list
(
args
.
train
,
target_dir
=
args
.
target_dir
,
split_ratio
=
config
.
split_ratio
)
prepare_csv
(
train_files
,
os
.
path
.
join
(
args
.
target_dir
,
"csv"
,
"train.csv"
),
config
)
prepare_csv
(
dev_files
,
os
.
path
.
join
(
args
.
target_dir
,
"csv"
,
"dev.csv"
),
config
)
if
__name__
==
"__main__"
:
if
__name__
==
"__main__"
:
parser
=
argparse
.
ArgumentParser
(
description
=
__doc__
)
parser
=
argparse
.
ArgumentParser
(
description
=
__doc__
)
...
@@ -148,18 +237,20 @@ if __name__ == "__main__":
...
@@ -148,18 +237,20 @@ if __name__ == "__main__":
"--train"
,
"--train"
,
required
=
True
,
required
=
True
,
nargs
=
'+'
,
nargs
=
'+'
,
help
=
"The jsonline files list for train"
)
help
=
"The jsonline files list for train
.
"
)
parser
.
add_argument
(
parser
.
add_argument
(
"--test"
,
required
=
True
,
help
=
"The jsonline file for test"
)
"--test"
,
required
=
True
,
help
=
"The jsonline file for test"
)
parser
.
add_argument
(
parser
.
add_argument
(
"--target_dir"
,
"--target_dir"
,
default
=
None
,
required
=
True
,
help
=
"The target directory stores the csv files and meta file."
)
parser
.
add_argument
(
"--config"
,
default
=
None
,
required
=
True
,
required
=
True
,
help
=
"The target directory stores the csv files and meta file"
)
type
=
str
,
parser
.
add_argument
(
"--config"
,
help
=
"configuration file"
)
default
=
None
,
required
=
True
,
type
=
str
,
help
=
"configuration file"
)
args
=
parser
.
parse_args
()
args
=
parser
.
parse_args
()
# parse the yaml config file
# parse the yaml config file
...
@@ -167,4 +258,5 @@ if __name__ == "__main__":
...
@@ -167,4 +258,5 @@ if __name__ == "__main__":
if
args
.
config
:
if
args
.
config
:
config
.
merge_from_file
(
args
.
config
)
config
.
merge_from_file
(
args
.
config
)
prepare_data
(
args
,
config
)
# prepare the csv file from jsonlines files
\ No newline at end of file
prepare_data
(
args
,
config
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录