Transcribe any audio or video file. Edit and view your transcripts in a standalone HTML editor.
Contents
- We strongly recommend using a CUDA-compatible graphics card, as transcription on a CPU is extremely slow.
- If you are using a graphics card, you need at least 8GB VRAM. Performance is better with 16GB VRAM.
- 8GB RAM
- Ensure you have a compatible NVIDIA driver and CUDA Version installed: https://pytorch.org/
- Install ffmpeg
- Windows: https://phoenixnap.com/kb/ffmpeg-windows
- Linux (Ubuntu):
sudo apt install ffmpeg
- Install conda
- Create a new Python environment, e.g.:
conda create --name transcribo python=3.10
- Activate your new environment:
conda activate transcribo
- Clone this repo.
- Install packages:
- Check the installed cuda version:
nvcc --version
- Run the following command with your specific cuda version. This example is for cuda version 11.8, edit the command for your installed version.
conda install pytorch==2.1.2 torchvision==0.16.2 torchaudio==2.1.2 pytorch-cuda=11.8 -c pytorch -c nvidia
pip install -r requirements.txt
- MacOS
- Don't do the above, but:
conda install pytorch==2.1.2 torchvision==0.16.2 torchaudio==2.1.2 -c pytorch pip install -r requirements.txt pip install -r requirements-mps.txt pip install --force --pre torch torchvision torchaudio --index-url https://download.pytorch.org/whl/nightly/cpu # when pytorch 2.6/7 is released, this line can be removed pip install --force-reinstall -v "numpy==1.26.3"` # hopefully also not needed in the future
- And set
DEVICE = "mps"
in your.env
file - You don't need to uninstall onnxruntime in the next step
- Don't do the above, but:
- Check the installed cuda version:
- Make sure, that the onnxruntime-gpu package is installed. Otherwise uninstall onnxruntime and install onnxruntime-gpu (if in doubt, just reinstall onnxruntime-gpu)
pip uninstall onnxruntime
pip install --force-reinstall onnxruntime-gpu
pip install --force-reinstall -v "numpy==1.26.3"
- Create a Huggingface access token
- Accept pyannote/segmentation) user conditions
- Accept pyannote/speaker-diarization-3.0 user conditions
- Create access token at hf.co/settings/tokens with read and write permissions.
- Create a
.env
file and add your access token. See the file.env_example
.
HF_AUTH_TOKEN = ...
- Edit all the variables of
.env_example
in your.env
file for your specific configuration. Make sure that your.env
file is in your.gitignore
.
- Install docker (on Windows use WSL2 backend)
- Run
docker-compose up -d --build
Start the worker and frontend scripts:
- Linux / MacOS
tmux new -s transcribe_worker
conda activate transcribo
- Linux:
python worker.py
- MacOS:
- The MPS/MLX implementation of all this has some massive memory leaks, so we do restart the worker after every transcription. Patches to prevent this are welcome.
while true; do python worker.py; done
- Exit tmux session with
CTRL-B
andD
. tmux new -s transcribe_frontend
conda activate transcribo
python main.py
- You can restore your sessions with
tmux attach -t transcribe_worker
andtmux attach -t transcribe_frontend
- Windows
- See
run_gui.bat
,run_transcribo.bat
andrun_worker.bat
- Make sure not to run the worker script multiple times. If more than one worker script is running, it will consume too much VRAM and significantly slow down the system.
- See
Description | |
---|---|
ONLINE | Boolean. If TRUE, exposes the frontend in your network. For https, you must provide a SSL cert and key file. See the nicegui documentation for more information |
SSL_CERTFILE | String. The file path to the SSL cert file |
SSL_KEYFILE | String. The file path to the SSL key file |
STORAGE_SECRET | String. Secret key for cookie-based identification of users |
ROOT | String. path to main.py and worker.py |
WINDOWS | Boolean. Set TRUE if you are running this application on Windows. |
DEVICE | String. 'cuda' if you are using a GPU. 'cpu' otherwise. |
ADDITIONAL_SPEAKERS | Integer. Number of additional speakers provied in the editor |
BATCH_SIZE | Integer. Batch size for Whisper inference. Recommended batch size is 4 with 8GB VRAM and 32 with 16GB VRAM. |
This application provides advanced transcription capabilities for confidential audio and video files using the state-of-the-art Whisper v3 large model (non-quantized). It offers top-tier transcription quality without licensing or usage fees, even for Swiss German.
- State-of-the-Art Transcription: Powered by Whisper v3 large model, ensuring high accuracy and reliability.
- Cost-Free: No license or usage-related costs, making it an affordable solution for everyone.
- High Performance: Transcribe up to 15 times faster than real-time, ensuring efficient processing.
- High-Quality Transcriptions: Exceptional transcription quality for English and local languages, with substantial accuracy for Swiss German.
- Speaker Diarisation: Automatic identification and differentiation of speakers within the audio.
- Multi-File Upload: Easily upload and manage multiple files for transcription.
- Predefined vocabulary: Define the spelling of ambiguous words and names.
- Transcript Export Options: Export transcriptions in various formats:
- Text file
- SRT file (for video subtitles)
- Synchronized viewer with integrated audio or video
- Integrated Editing: Edit transcriptions directly within the application, synchronously linked with the source video or audio. The editor is open-source and requires no installation.
- General Text Editing Functions: Standard text editing features for ease of use.
- Segments: Add or remove speech segments.
- Speaker Naming: Assign names to identified speakers for clarity.
- Power User Shortcuts: Keyboard shortcuts for enhanced navigation and control (start, stop, forward, backward, etc.).
This project is a collaborative effort of these people of the cantonal administration of Zurich:
- Stephan Walder - Leiter Digitale Transformation, Oberstaatsanwaltschaft Kanton Zürich
- Dominik Frefel - Team Data, Statistisches Amt
- Patrick Arnecke - Team Data, Statistisches Amt
Please share your feedback and let us know how you use the app in your institution. You can write an email or share your ideas by opening an issue or a pull requests.
Please note, we use Ruff for linting and code formatting with default settings.
This transcription software (the Software) incorporates the open-source model Whisper Large v3 (the Model) and has been developed according to and with the intent to be used under Swiss law. Please be aware that the EU Artificial Intelligence Act (EU AI Act) may, under certain circumstances, be applicable to your use of the Software. You are solely responsible for ensuring that your use of the Software as well as of the underlying Model complies with all applicable local, national and international laws and regulations. By using this Software, you acknowledge and agree (a) that it is your responsibility to assess which laws and regulations, in particular regarding the use of AI technologies, are applicable to your intended use and to comply therewith, and (b) that you will hold us harmless from any action, claims, liability or loss in respect of your use of the Software.