Skip to main content

Replace video audio with high-quality dedicated recordings

Project description

SoundGraft

Replace video clip audio with matched segments from a dedicated audio recording.

When you record an event with both a camera and a separate high-quality audio recorder, SoundGraft automatically aligns each video clip to the audio timeline and swaps in the better audio track. It also cleans up the replacement audio by attenuating applause and impulse noise, then peak-normalizes the result.

How it works

  1. File classification — Scans the input directory and sorts files into audio recordings and video clips by extension.
  2. Event grouping — Groups consecutive audio segments into events using a file-size heuristic (a short segment followed by a full-length one marks an event boundary).
  3. Alignment — Uses Chromaprint fingerprint correlation to find where each video clip sits within the audio timeline. Metadata timestamps provide a search hint when available; falls back to a full scan otherwise.
  4. Audio processing — For each matched clip:
    • Cuts the corresponding segment from the audio recording
    • Detects and attenuates applause sections (spectral flatness analysis)
    • Detects and attenuates impulse noise (transient peak analysis)
    • Peak-normalizes to 0 dBFS
  5. Muxing — Replaces the video's audio track with the processed audio using ffmpeg.

Per-clip .log files are written to the output directory with alignment, applause, impulse, and normalization details.

Installation

pip install soundgraft

You also need these system tools:

  • ffmpeg / ffprobe
  • sox
  • fpcalc (from libchromaprint-tools)

On Debian/Ubuntu:

sudo apt install ffmpeg sox libchromaprint-tools

Usage

soundgraft --input <input_dir> --output <output_dir> [options]

Place all raw audio recordings and video clips in a single input directory. Output videos (with replaced audio) and per-clip log files are written to the output directory.

Options

Flag Description
--input DIR Directory containing raw audio and video files (required)
--output DIR Directory for output files (required)
--clip N Process only video clip number N (1-indexed)
--from-clip N Process video clips from N onwards
--it-is-what-it-is Include low-confidence matches instead of skipping them
--no-hint Skip metadata timestamp heuristic, always do full scan
--keep-original-audio Keep the original video audio as a second track
--temp-dir DIR Directory for temporary files (default: system temp)

Supported formats

  • Audio: .wav, .flac, .mp3, .ogg, .aac
  • Video: .mp4, .mov, .avi, .mkv, .mts

Example

soundgraft --input ./concert-raw --output ./concert-fixed

This scans concert-raw/ for audio and video files, aligns each video clip to the audio recording, processes the audio, and writes the final videos to concert-fixed/.

License

Apache-2.0

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

soundgraft-0.1.0.tar.gz (34.7 kB view details)

Uploaded Source

Built Distribution

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

soundgraft-0.1.0-py3-none-any.whl (17.1 kB view details)

Uploaded Python 3

File details

Details for the file soundgraft-0.1.0.tar.gz.

File metadata

  • Download URL: soundgraft-0.1.0.tar.gz
  • Upload date:
  • Size: 34.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for soundgraft-0.1.0.tar.gz
Algorithm Hash digest
SHA256 b626fbf4381a87a03c9e29320632898b56804b4f72f2e0538827ac0e82d8ef01
MD5 d378e70f018c2874d1b60f305d197dcf
BLAKE2b-256 3cb9cc4b649866422820a05bfb2da5ddf9475635ed41bc2e8538f8b176a9c4ec

See more details on using hashes here.

File details

Details for the file soundgraft-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: soundgraft-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 17.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for soundgraft-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2f092ea56f6facf16958e568f92b93673c8d2ddb0afef134a31c40cf032f63cf
MD5 5be6fc6a62bbdf8623adcb9de9c522f2
BLAKE2b-256 21d028fb649b41bf350f9c591238a59843caf8c5909ae1c4aa4efba952fb26a1

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