Skip to main content

Modern speech recognition with word-level timestamps and speaker diarization. Fork of WhisperX with torch 2.6+, pyannote 4.x compatibility.

Project description

MurmurAI

MurmurAI Logo

Modern speech recognition with word-level timestamps and speaker diarization

PyPI CI Python License


MurmurAI is a fork of WhisperX with modern dependency support:

  • PyTorch 2.6+ compatibility (weights_only patches)
  • Pyannote 4.x support (token parameter migration)
  • Torchaudio 2.9+ compatibility (audio backend fixes)
  • Python 3.10-3.13 tested

Features

  • Word-level timestamps via phoneme alignment
  • Speaker diarization with pyannote.audio
  • Batch inference for 70x realtime transcription
  • VAD preprocessing (pyannote or silero)
  • Multiple output formats: SRT, VTT, TXT, TSV, JSON

Installation

pip install murmurai-core

Or with uv:

uv add murmurai-core

Quick Start

Python API

import murmurai

# Load model
model = murmurai.load_model("large-v3-turbo", device="cuda", compute_type="float16")

# Transcribe
audio = murmurai.load_audio("audio.mp3")
result = model.transcribe(audio, batch_size=16)

# Align (word-level timestamps)
model_a, metadata = murmurai.load_align_model(language_code=result["language"], device="cuda")
result = murmurai.align(result["segments"], model_a, metadata, audio, device="cuda")

# Diarization (speaker labels)
from pyannote.audio import Pipeline
diarize_model = Pipeline.from_pretrained("pyannote/speaker-diarization-3.1", use_auth_token="YOUR_HF_TOKEN")
diarize_segments = diarize_model(audio)
result = murmurai.assign_word_speakers(diarize_segments, result)

CLI

Basic transcription:

murmurai-core audio.mp3

With specific model and language:

murmurai-core audio.mp3 --model large-v3-turbo --language en

With speaker diarization:

murmurai-core audio.mp3 --model large-v3-turbo --diarize --hf_token YOUR_HF_TOKEN

Output to specific format and directory:

murmurai-core audio.mp3 --output_format srt --output_dir ./transcripts

Run without installing (via uvx):

uvx murmurai-core audio.mp3 --model large-v3-turbo

Common options:

Option Description Default
--model Whisper model (tiny, base, small, medium, large-v3, large-v3-turbo) small
--language Audio language (e.g., en, pt, es, fr) auto-detect
--device cuda or cpu cuda
--output_format srt, vtt, txt, tsv, json, all all
--output_dir Output directory .
--diarize Enable speaker diarization off
--hf_token HuggingFace token (required for diarization) -
--batch_size Batch size for inference 8
--compute_type float16, float32, int8 float16

Requirements

  • NVIDIA GPU with CUDA support (or CPU mode)
  • HuggingFace token for diarization models

Accept the license at pyannote/speaker-diarization-3.1 before using diarization.

Migration from WhisperX

# Before
import whisperx

# After
import murmurai  # drop-in replacement

All APIs are identical. Just change the import.

Credits

MurmurAI builds on the excellent work of:


Made with ❤️ by Namastex Labs

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

murmurai_core-1.0.3.tar.gz (16.8 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

murmurai_core-1.0.3-py3-none-any.whl (16.5 MB view details)

Uploaded Python 3

File details

Details for the file murmurai_core-1.0.3.tar.gz.

File metadata

  • Download URL: murmurai_core-1.0.3.tar.gz
  • Upload date:
  • Size: 16.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for murmurai_core-1.0.3.tar.gz
Algorithm Hash digest
SHA256 be51bba998c0e20931039a45f5f98ff6bcfe1c53efeab818dfcc1cc6e17add6e
MD5 c76188e7fa9f0d941e112351224cf475
BLAKE2b-256 75ba0051e3ece10b8e337dd5b531940fb50e21c06eebeb0e9da7e725d676330b

See more details on using hashes here.

File details

Details for the file murmurai_core-1.0.3-py3-none-any.whl.

File metadata

  • Download URL: murmurai_core-1.0.3-py3-none-any.whl
  • Upload date:
  • Size: 16.5 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for murmurai_core-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 742d8dc380861037aa60245ba8eb7224d60f52c9d52577f55326efc7eb39d6a8
MD5 af3d4f8d31e0913b0ef14d1e2b399c62
BLAKE2b-256 065a29aae64751cdc861f7391c49b352bc3706449ca19356228da6b2dcdb9fdf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page