2022-11-25 19:06:56 +02:00
# command
This is a basic Voice Assistant example that accepts voice commands from the microphone.
More info is available in [issue #171 ](https://github.com/ggerganov/whisper.cpp/issues/171 ).
2022-11-25 19:53:50 +02:00
```bash
2022-11-25 19:06:56 +02:00
# Run with default arguments and small model
./command -m ./models/ggml-small.en.bin -t 8
# On Raspberry Pi, use tiny or base models + "-ac 768" for better performance
2022-12-13 21:36:29 +02:00
./command -m ./models/ggml-tiny.en.bin -ac 768 -t 3 -c 0
2023-01-06 18:59:26 +02:00
```
https://user-images.githubusercontent.com/1991296/204038393-2f846eae-c255-4099-a76d-5735c25c49da.mp4
Web version: [examples/command.wasm ](/examples/command.wasm )
## Guided mode
2022-12-13 21:36:29 +02:00
2023-01-06 18:59:26 +02:00
"Guided mode" allows you to specify a list of commands (i.e. strings) and the transcription will be guided to classify your command into one from the list. This can be useful in situations where a device is listening only for a small subset of commands.
Initial tests show that this approach might be extremely efficient in terms of performance, since it integrates very well with the "partial Encoder" idea from #137 .
```bash
2022-12-13 21:36:29 +02:00
# Run in guided mode, the list of allowed commands is in commands.txt
./command -m ./models/ggml-base.en.bin -cmd ./examples/command/commands.txt
# On Raspberry Pi, in guided mode you can use "-ac 128" for extra performance
./command -m ./models/ggml-tiny.en.bin -cmd ./examples/command/commands.txt -ac 128 -t 3 -c 0
2022-11-25 19:06:56 +02:00
```
2023-01-06 18:59:26 +02:00
https://user-images.githubusercontent.com/1991296/207435352-8fc4ed3f-bde5-4555-9b8b-aeeb76bee969.mp4
2022-11-25 20:23:58 +02:00
2022-11-26 11:40:06 +02:00
2022-11-25 19:06:56 +02:00
## Building
The `command` tool depends on SDL2 library to capture audio from the microphone. You can build it like this:
```bash
# Install SDL2 on Linux
sudo apt-get install libsdl2-dev
# Install SDL2 on Mac OS
brew install sdl2
make command
```