A Rust library for working with the TEN VAD (Voice Activity Detector) ONNX model. A low-latency, high-performance and lightweight solution to detect speech in audio streams. 🚀
- 🎙️ Real-time voice activity detection
- 🦀 Pure Rust API
- 🧠 Powered by ONNX Runtime
- 📦 Easy integration into your audio projects
- 🛠️ Example code for microphone and WAV file VAD
Add to your Cargo.toml:
[dependencies]
ten-vad-rs = "0.1.1" # Replace with the latest versionHere's a simple example using a WAV file:
use ten_vad_rs::TenVad;
let mut vad = TenVad::new("onnx/ten-vad.onnx", 16000).unwrap();
let audio_frame = vec![0i16; 256]; // 16-bit PCM audio samples in 16kHz
let vad_score = vad.process_frame(&audio_frame).unwrap();See the examples/ directory for more advanced usage:
wav_file_vad.rs— Run VAD on a WAV filemicrophone_vad.rs— Real-time VAD from microphone
Requires Rust and a working ONNX Runtime environment. Build with:
cargo build --releaseContributions, issues, and feature requests are welcome! Feel free to open an issue or submit a pull request.
Licensed under the Apache-2.0 license.