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.5rc1.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.5rc1-py3-none-any.whl (16.5 MB view details)

Uploaded Python 3

File details

Details for the file murmurai_core-1.0.5rc1.tar.gz.

File metadata

  • Download URL: murmurai_core-1.0.5rc1.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.5rc1.tar.gz
Algorithm Hash digest
SHA256 e31ff0f5b19c7549e4af34a5b05a82db5ca3c3cab17cad2db0f899dfe2d8a8cc
MD5 785dd91cfd9a518018a3dc9a01f5d47e
BLAKE2b-256 f23d4201849bac8e9d799f9fac5c306fd7cc718d12496c92e6020b7b3a73b0a8

See more details on using hashes here.

File details

Details for the file murmurai_core-1.0.5rc1-py3-none-any.whl.

File metadata

File hashes

Hashes for murmurai_core-1.0.5rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 83637b4363131917d044be590b395a3cd87db2d1c011de900d6cb6ec83e66e06
MD5 a4fb03d0ad8ebd4e0eb24bac06534b1d
BLAKE2b-256 4d62ea296007f186c83abe91b9ca2f07559c2f51550ac5f7362e66e4998ef0df

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