mirror of
https://github.com/snakers4/silero-vad.git
synced 2026-02-05 01:49:22 +08:00
84 lines
2.8 KiB
Python
84 lines
2.8 KiB
Python
dependencies = ['torch', 'torchaudio']
|
|
import torch
|
|
import json
|
|
|
|
from utils_vad import (init_jit_model,
|
|
get_speech_timestamps,
|
|
get_number_ts,
|
|
get_language,
|
|
get_language_and_group,
|
|
save_audio,
|
|
read_audio,
|
|
VADIterator,
|
|
collect_chunks,
|
|
drop_chunks,
|
|
donwload_onnx_model)
|
|
|
|
|
|
def silero_vad(**kwargs):
|
|
"""Silero Voice Activity Detector
|
|
Returns a model with a set of utils
|
|
Please see https://github.com/snakers4/silero-vad for usage examples
|
|
"""
|
|
hub_dir = torch.hub.get_dir()
|
|
model = init_jit_model(model_path=f'{hub_dir}/snakers4_silero-vad_master/files/silero_vad.jit')
|
|
utils = (get_speech_timestamps,
|
|
save_audio,
|
|
read_audio,
|
|
VADIterator,
|
|
collect_chunks)
|
|
|
|
return model, utils
|
|
|
|
|
|
def silero_number_detector(**kwargs):
|
|
"""Silero Number Detector
|
|
Returns a model with a set of utils
|
|
Please see https://github.com/snakers4/silero-vad for usage examples
|
|
"""
|
|
torch.hub.download_url_to_file('https://models.silero.ai/vad_models/number_detector.jit', 'number_detector.jit')
|
|
model = init_jit_model(model_path='number_detector.jit')
|
|
utils = (get_number_ts,
|
|
save_audio,
|
|
read_audio,
|
|
collect_chunks,
|
|
drop_chunks,
|
|
donwload_onnx_model)
|
|
|
|
return model, utils
|
|
|
|
|
|
def silero_lang_detector(**kwargs):
|
|
"""Silero Language Classifier
|
|
Returns a model with a set of utils
|
|
Please see https://github.com/snakers4/silero-vad for usage examples
|
|
"""
|
|
torch.hub.download_url_to_file('https://models.silero.ai/vad_models/number_detector.jit', 'number_detector.jit')
|
|
model = init_jit_model(model_path='number_detector.jit')
|
|
utils = (get_language,
|
|
read_audio,
|
|
donwload_onnx_model)
|
|
|
|
return model, utils
|
|
|
|
|
|
def silero_lang_detector_95(**kwargs):
|
|
"""Silero Language Classifier (95 languages)
|
|
Returns a model with a set of utils
|
|
Please see https://github.com/snakers4/silero-vad for usage examples
|
|
"""
|
|
|
|
hub_dir = torch.hub.get_dir()
|
|
torch.hub.download_url_to_file('https://models.silero.ai/vad_models/lang_classifier_95.jit', 'lang_classifier_95.jit')
|
|
model = init_jit_model(model_path='lang_classifier_95.jit')
|
|
|
|
with open(f'{hub_dir}/snakers4_silero-vad_master/files/lang_dict_95.json', 'r') as f:
|
|
lang_dict = json.load(f)
|
|
|
|
with open(f'{hub_dir}/snakers4_silero-vad_master/files/lang_group_dict_95.json', 'r') as f:
|
|
lang_group_dict = json.load(f)
|
|
|
|
utils = (get_language_and_group, read_audio, donwload_onnx_model)
|
|
|
|
return model, lang_dict, lang_group_dict, utils
|