modified compute_fbank_librispeech.py to minimize resource utilization

This commit is contained in:
RedSheep 2025-03-12 12:00:48 +08:00
parent 76d3df55a0
commit b793c5e958

View File

@ -133,6 +133,7 @@ def compute_fbank_librispeech(
logging.info(f"{partition} already exists - skipping.") logging.info(f"{partition} already exists - skipping.")
continue continue
logging.info(f"Processing {partition}") logging.info(f"Processing {partition}")
cut_set = CutSet.from_manifests( cut_set = CutSet.from_manifests(
recordings=m["recordings"], recordings=m["recordings"],
supervisions=m["supervisions"], supervisions=m["supervisions"],
@ -142,20 +143,44 @@ def compute_fbank_librispeech(
if bpe_model: if bpe_model:
cut_set = filter_cuts(cut_set, sp) cut_set = filter_cuts(cut_set, sp)
if perturb_speed: if perturb_speed:
logging.info(f"Doing speed perturb") logging.info("Doing speed perturb")
cut_set = ( cut_set = (
cut_set cut_set
+ cut_set.perturb_speed(0.9) + cut_set.perturb_speed(0.9)
+ cut_set.perturb_speed(1.1) + cut_set.perturb_speed(1.1)
) )
# 修改這部分代碼
if ex is None:
# 為 None 的情況(本地執行)創建自定義進程池上下文
import multiprocessing as mp
from concurrent.futures import ProcessPoolExecutor
# 計算工作數
actual_jobs = (
min(num_jobs * 2, 20) if "train" in partition else num_jobs
)
# 使用 forkserver 方法
ctx = mp.get_context("forkserver")
with ProcessPoolExecutor(
max_workers=actual_jobs, mp_context=ctx
) as local_executor:
cut_set = cut_set.compute_and_store_features( cut_set = cut_set.compute_and_store_features(
extractor=extractor, extractor=extractor,
storage_path=f"{output_dir}/{prefix}_feats_{partition}", storage_path=f"{output_dir}/{prefix}_feats_{partition}",
# when an executor is specified, make more partitions executor=local_executor,
num_jobs=num_jobs if ex is None else min(num_jobs * 2, 20), storage_type=LilcomChunkyWriter,
)
else:
# 分佈式環境,使用提供的執行器
cut_set = cut_set.compute_and_store_features(
extractor=extractor,
storage_path=f"{output_dir}/{prefix}_feats_{partition}",
num_jobs=min(num_jobs * 2, 20),
executor=ex, executor=ex,
storage_type=LilcomChunkyWriter, storage_type=LilcomChunkyWriter,
) )
cut_set.to_file(output_dir / cuts_filename) cut_set.to_file(output_dir / cuts_filename)