Standalone chunked TTS voiceover + Whisper timing CLI
Project description
Voiceover Pipeline
Standalone CLI для генерации озвучки + Whisper timing из Markdown-сценариев.
Четыре TTS-провайдера: Polza GPT Audio, Polza TTS, OpenRouter TTS, Qwen3-TTS (GPU).
Whisper CPU small — точные тайминги для Remotion-анимаций и субтитров.
Agent-grade JSON-контракт: --json, semantic exit codes, manifest.json.
Install
Console scripts: voiceover and voiceover-pipeline (both work).
| Manager | Base | + Whisper | + Qwen GPU | + All extras |
|---|---|---|---|---|
| uvx (no install) | uvx voiceover-pipeline doctor |
uvx --from "voiceover-pipeline[timing-whisper]" voiceover-pipeline generate --with-timings ... |
uvx --from "voiceover-pipeline[voiceover-qwen]" voiceover-pipeline generate --provider qwen-local ... |
uvx --from "voiceover-pipeline[timing-whisper,voiceover-qwen,cuda]" ... |
| pipx | pipx install voiceover-pipeline |
pipx install "voiceover-pipeline[timing-whisper]" |
pipx install "voiceover-pipeline[voiceover-qwen]" |
pipx install "voiceover-pipeline[timing-whisper,voiceover-qwen,cuda]" |
| pip | pip install voiceover-pipeline |
pip install "voiceover-pipeline[timing-whisper]" |
pip install "voiceover-pipeline[voiceover-qwen]" |
pip install "voiceover-pipeline[timing-whisper,voiceover-qwen,cuda]" |
| uv pip | uv pip install voiceover-pipeline |
uv pip install "voiceover-pipeline[timing-whisper]" |
uv pip install "voiceover-pipeline[voiceover-qwen]" |
uv pip install "voiceover-pipeline[timing-whisper,voiceover-qwen,cuda]" |
From source
git clone https://github.com/VladimirMonin/voiceover-pipeline
cd voiceover-pipeline
uv sync --group dev --extra timing-whisper
uv run voiceover doctor
First run
.envis searched in CWD and upwards through parent directories.- Whisper model (~486 MB) auto-downloads from HuggingFace on first
--with-timings. Subsequent runs use cache. - Qwen-local requires NVIDIA GPU + CUDA drivers (~4 GB VRAM).
API Keys
Create .env in your working directory (CWD or any parent directory — searched upwards):
POLZA_API_KEY=pza_...
OPENROUTER_API_KEY=sk-or-v1-...
Never commit .env.
Golden Command
voiceover generate `
--provider polza-chat-audio `
--model "openai/gpt-audio-mini" `
--script "script.md" `
--run-id "prod" `
--with-timings `
--word-timestamps `
--json `
--overwrite
Результат (JSON stdout):
{"status": "success", "provider": "polza-chat-audio", "run_id": "prod",
"duration_ms": 25520, "segment_count": 8, "cost": {"total": 0.0146, "currency": "RUB"}}
Результат (JSON stdout):
{"status": "success", "provider": "polza-chat-audio", "run_id": "prod",
"duration_ms": 25520, "segment_count": 8, "cost": {"total": 0.0146, "currency": "RUB"}}
Что на выходе
out/<run-id>/
├── manifest.json ← entry-point для агентов
├── <run-id>-voiceover-<model>.mp3 ← полный MP3
├── <run-id>-voiceover-<model>.json ← run-манифест
├── <run-id>.timings.json ← Whisper-сегменты (ms)
├── <run-id>.srt ← субтитры SRT
└── chunks/
├── chunk_01.mp3 ... chunk_NN.mp3
└── chunks.json
Команды
| Команда | Зачем |
|---|---|
doctor |
Проверить окружение |
validate --script X |
Проверить сценарий |
list providers/voices/timing-models |
Доступные модели |
split --script X |
Чанки сценария |
generate |
Полная генерация + тайминги |
timings --audio X |
Тайминги из готового MP3 |
Все команды поддерживают --json.
Модели и цены
| Провайдер | Модель | Цена минуты |
|---|---|---|
| Polza | openai/gpt-audio-mini |
~0.004 ₽/мин (anomalous 200s smoke — model added speech, needs rerun) |
| Polza | openai/gpt-audio |
~7.00 ₽/мин |
| Polza | openai/gpt-4o-mini-tts |
~1.07 ₽/мин |
| Polza | elevenlabs/text-to-speech-turbo-2-5 |
~3.51 ₽/мин |
| Polza | elevenlabs/text-to-speech-multilingual-v2 |
~7.57 ₽/мин |
| OpenRouter | google/gemini-3.1-flash-tts-preview |
~$0.030/мин |
| OpenRouter | openai/gpt-4o-mini-tts-2025-12-15 |
~$0.00041/мин |
| Qwen3-TTS | CustomVoice (preset/clone) | Бесплатно (GPU) |
Тестирование
uv sync --group dev --extra timing-whisper
uv run pytest
61 тест: JSON-контракт, exit codes, валидация, output policy, providers.
Agent Skill
OpenCode agent skill — устанавливает pipeline, выбирает провайдера, генерирует озвучку:
- Source: https://github.com/VladimirMonin/voiceover-pipeline/tree/v0.4.0/docs/skills/voiceover-pipeline
- Download: https://github.com/VladimirMonin/voiceover-pipeline/releases/tag/v0.4.0
Legal / Provider Notes
This project is an independent CLI wrapper around third-party providers. It is not affiliated with OpenAI, Google, OpenRouter, Polza.ai, Qwen, or CTranslate2 / faster-whisper. Provider names and model names are used solely for integration and documentation purposes. Generated audio usage is subject to the selected provider's terms of service. Do not upload private voice samples or generated speech without permission.
License
MIT. See LICENSE.
Документация
- Agent CLI Contract — JSON-контракт, exit codes, stdout/stderr, safety rules
- Remotion Workflow — как агент Remotion использует pipeline
- Artifacts & Analysis — JSON-схемы, обработка аудио, сравнение моделей
- Whisper Timing — модель, device, compute, word timestamps
- Troubleshooting — типовые ошибки и их коды
- Polza Models — голоса, цены, особенности
- Polza TTS Models — OpenAI TTS, ElevenLabs через Polza AI
- OpenRouter TTS — Gemini, OpenAI TTS через OpenRouter
- OpenCode Skill — Agent skill для установки и озвучки
- Qwen Local — preset-голоса, клонирование, GPU
Project details
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 voiceover_pipeline-0.4.0.tar.gz.
File metadata
- Download URL: voiceover_pipeline-0.4.0.tar.gz
- Upload date:
- Size: 974.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b92319f2295d5285e26cdce9384a0258d1368efa4f4836a689afe390ab76a303
|
|
| MD5 |
57561d43b9bdb153b00078fc2f33cc99
|
|
| BLAKE2b-256 |
192d76d79095317a0718e8670c7fc16247de4496f9c75758e2abe6a648df4638
|
File details
Details for the file voiceover_pipeline-0.4.0-py3-none-any.whl.
File metadata
- Download URL: voiceover_pipeline-0.4.0-py3-none-any.whl
- Upload date:
- Size: 31.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4c13325b8240a94551cede18347a5149c73417bd9a66ae45aa4597c4fa213c5d
|
|
| MD5 |
804df473e6b5fa3e61fa68f5ea9aa1b9
|
|
| BLAKE2b-256 |
9596cb08e33a6346528a8624712a0cf8a653b1bae01244122daeb5c99fc0cf8e
|