https://github.com/ganymedenil/go-webrtcvad
cgo interface to WebRTC Voice Activity Dectection
https://github.com/ganymedenil/go-webrtcvad
cgo vad webrtc webrtc-vad webrtcvad
Last synced: 7 months ago
JSON representation
cgo interface to WebRTC Voice Activity Dectection
- Host: GitHub
- URL: https://github.com/ganymedenil/go-webrtcvad
- Owner: GanymedeNil
- Created: 2019-10-02T01:51:09.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2019-12-10T08:20:00.000Z (almost 6 years ago)
- Last Synced: 2025-01-17T21:43:18.938Z (9 months ago)
- Topics: cgo, vad, webrtc, webrtc-vad, webrtcvad
- Language: C
- Homepage:
- Size: 93.8 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
A quick n' dirty Go port of [py-webrtcvad](https://github.com/wiseman/py-webrtcvad) Voice Activity Detector (VAD).
A VAD classifies a piece of audio data as being voiced or unvoiced. It can be useful for telephony and speech recognition.
The VAD that Google developed for the WebRTC project is reportedly one of the best available, being fast, modern and free.
This project is an upgraded version of [maxhawkins/go-webrtcvad](https://github.com/maxhawkins/go-webrtcvad)
Usage
-----Go-get the package. You don't need to have webrtc installed.
```
go get github.com/GanymedeNil/go-webrtcvad
```Feed raw audio samples into the VAD:
```go
reader, err := wav.NewReader("test.wav")
if err != nil {
log.Fatal(err)
}vad, err := webrtcvad.New()
if err != nil {
log.Fatal(err)
}if err := vad.SetMode(2); err != nil {
log.Fatal(err)
}rate := 32000 // kHz
frame := make([]byte, 320*2)if ok := vad.ValidRateAndFrameLength(rate, len(frame)); !ok {
log.Fatal("invalid rate or frame length")
}
for {
_, err := io.ReadFull(reader, frame)
if err == io.EOF || err == io.ErrUnexpectedEOF {
break
}
if err != nil {
log.Fatal(err)
}active, err := vad.Process(rate, frame)
if err != nil {
log.Fatal(err)
}fmt.Println(active)
}
```