Voice UI for AI panes - push-to-talk voice control over tmux agent panes
Project description
Voice UI for AI panes: push-to-talk voice control for your tmux agent panes, on macOS, with on-device speech.
vupai (say "voo-pie") is a Voice UI for your AI panes.
Hold a key, speak, and what you say is typed into the right tmux pane: the one you're looking at, or an agent you call by name ("atlas, run the tests"). Speech-to-text runs on-device with NVIDIA Parakeet (via Apple MLX): no cloud, no API keys.
Built for a tmux-centric workflow where you keep several coding agents and
shells open at once and want to drive them by voice without reaching for the
mouse. New panes launch an agent by default (claude out of the box) and should
work with other agentic coding tools (Codex, Gemini, …), though testing so far
has focused on Claude Code.
📚 Full documentation: itsjrsa.github.io/vupai · 🎬 demo clips
Install
vupai is macOS Apple-Silicon only (it depends on Apple MLX for on-device
speech). It needs tmux, sox, and uv:
brew install tmux sox uv
uv tool install vupai
vupai setup # one-time bootstrap: mic, hotkeys, model download, macOS permissions
The Parakeet model (~2 GB) downloads automatically on first use. Full details (requirements, from-source install, permissions) are in the install and setup docs.
Quickstart
vupai # attach-or-create the session named after the cwd
Then hold a push-to-talk key and speak:
- Right-Option (dictation): what you say is typed into the focused pane. Start with a pane's name ("atlas, run the tests") to address it anywhere.
- Right-Command (system): voice commands that act on the panes instead of typing: "create 3 panes", "focus atlas", "board", "note: fix the retry logic", "everyone, pull main".
It's still tmux: every normal binding keeps working, and vupai runs on its own tmux server so your existing setup is untouched.
Learn more
The documentation site covers everything:
- Usage · Voice commands · Silent mode (no mic)
- Multi-agent supervision: board · activity ledger · review · task pile · squad
- Reference: configuration · SSH hosts · tmux tips · uninstall · roadmap
Contributing? See AGENTS.md. Ideas and PRs are welcome: open an issue.
License
MIT. (Note: pynput is LGPL-3.0 and the Parakeet model weights are
CC-BY-4.0; both are runtime dependencies, not part of this repo's code.)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file vupai-0.9.0.tar.gz.
File metadata
- Download URL: vupai-0.9.0.tar.gz
- Upload date:
- Size: 159.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3a213789e9e60bcb641aeeebd2f4c7fbfccecc3446890dd5799a541d9ba23897
|
|
| MD5 |
6332bda8fac1231952c521fc750176e4
|
|
| BLAKE2b-256 |
8e521c4bf73c89ec1ba29d6003dd7d33d388719b5f69dc97866286a7ee8cced1
|
Provenance
The following attestation bundles were made for vupai-0.9.0.tar.gz:
Publisher:
publish.yml on itsjrsa/vupai
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
vupai-0.9.0.tar.gz -
Subject digest:
3a213789e9e60bcb641aeeebd2f4c7fbfccecc3446890dd5799a541d9ba23897 - Sigstore transparency entry: 2064100249
- Sigstore integration time:
-
Permalink:
itsjrsa/vupai@29ff1f8410fbf134281f9daa6869094c95b57498 -
Branch / Tag:
refs/tags/v0.9.0 - Owner: https://github.com/itsjrsa
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@29ff1f8410fbf134281f9daa6869094c95b57498 -
Trigger Event:
release
-
Statement type:
File details
Details for the file vupai-0.9.0-py3-none-any.whl.
File metadata
- Download URL: vupai-0.9.0-py3-none-any.whl
- Upload date:
- Size: 177.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6070120f8b0a5c4508907c89804e2f8fc0ba24f753a96f46ce157a207a50eacf
|
|
| MD5 |
f22fba332d938a914d15c2d8828cce29
|
|
| BLAKE2b-256 |
505e55ebde839947569e844bfc8a5f182c9294d29e959e877f2ac5cb64eb004d
|
Provenance
The following attestation bundles were made for vupai-0.9.0-py3-none-any.whl:
Publisher:
publish.yml on itsjrsa/vupai
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
vupai-0.9.0-py3-none-any.whl -
Subject digest:
6070120f8b0a5c4508907c89804e2f8fc0ba24f753a96f46ce157a207a50eacf - Sigstore transparency entry: 2064100257
- Sigstore integration time:
-
Permalink:
itsjrsa/vupai@29ff1f8410fbf134281f9daa6869094c95b57498 -
Branch / Tag:
refs/tags/v0.9.0 - Owner: https://github.com/itsjrsa
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@29ff1f8410fbf134281f9daa6869094c95b57498 -
Trigger Event:
release
-
Statement type: