Skip to main content

Metrics to measure the quality of audio

Project description

Audio Metrics

PyPI version

This repository contains a python package to compute distribution-based quality metrics for audio data using embeddings, with a focus on music.

It features the following metrics:

The measures have in common that they compare a set of candidate audio tracks against a set of reference tracks, rather than evaluating individual tracks, and they all work on embedding representations of audio, obtained from models pretrained on tasks like audio classification.

The first two measures are typically used to measure audio quality (i.e. the naturalness of the sound, and the absence of acoustic artifacts). Density and Coverage explicitly measure how well the candidate set coincides with the reference set by comparing the embedding manifolds.

The Accompaniment Prompt Adherence measures operates on sets whose elements are pairs of audio tracks, typically a mix and an accompaniment, and quantifies how well the accompaniment fits to the mix.

The measures can be combined with embeddings from any of the following models:

  • VGGish - https://arxiv.org/abs/1609.09430 Trained on audio event classification. 128-dimensional embeddings from the last feature layer before the classification layer.

  • Laion CLAP - https://github.com/LAION-AI/CLAP using either the checkpoint trained on music and speech, or the checkpoint trained on music only; Embeddings from the last three layers (512, 512, and 128-dimensional)

Installation

Install from PyPI:

pip install audio-metrics

To run the examples, install with the examples dependencies:

pip install 'audio-metrics[examples]'

Development Installation

For development or to use the latest version from source:

git clone https://github.com/SonyCSLParis/audio-metrics.git
cd audio-metrics
pip install -e '.[dev]'

Usage

The following examples demonstrate the use of the package. For more examples see ./examples directory.

import numpy as np
from audio_metrics import AudioMetrics

sr = 48000
n_seconds = 5

n_windows = 100
window_len = sr * n_seconds

# create random audio signals
reference = np.random.random((n_windows, window_len))
candidate = np.random.random((n_windows, window_len))

metrics = AudioMetrics(
    metrics=[
        "prdc",  # precision, recall, density, coverage
        "fad",  # frechet audio distance
        "kd",  # kernel distance
    ],
    input_sr=sr,
)
metrics.add_reference(reference)

print(metrics.evaluate(candidate))

# To compute APA, the input data must be pairs of context and stem (in the
# trailing dimension)
reference = np.random.random((n_windows, window_len, 2))
# Data can also be passed as a generator, to facilitate processing larger
# datasets
candidate = (np.random.random((window_len, 2)) for _ in range(n_windows))

# stem-only metrics (like FAD), can be computed simultaneously with APA
metrics = AudioMetrics(
    metrics=["fad", "apa"],
    input_sr=sr,
)
metrics.add_reference(reference)
print(metrics.evaluate(candidate))

When computing APA the reference and candidate sets must be pairs of context and stem. Note that when FAD and/or PRDC are computed as additional metrics, these are only computed for the stems (the contexts are ignored for these metrics).

Citation

To cite this work, please use:

M. Grachten and J. Nistal. (2025). Accompaniment Prompt Adherence: A Measure for Evaluating Music Accompaniment Systems. Proceedings of the International Conference on Acoustics, Speech, and Signal Processing. IEEE. Hyderabad, India.

@inproceedings{grachten2025accompaniment,
  title        = {Accompaniment Prompt Adherence: A Measure for Evaluating Music Accompaniment Systems},
  author       = {Grachten, Maarten and Nistal, Javier},
  booktitle    = {ICASSP 2025-2025 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP)},
  pages        = {1--5},
  year         = {2025},
  organization = {IEEE},
  address      = {Hyderabad, India}
  month        = apr
}

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

audio_metrics-1.0.4.tar.gz (39.9 kB view details)

Uploaded Source

Built Distribution

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

audio_metrics-1.0.4-py3-none-any.whl (41.5 kB view details)

Uploaded Python 3

File details

Details for the file audio_metrics-1.0.4.tar.gz.

File metadata

  • Download URL: audio_metrics-1.0.4.tar.gz
  • Upload date:
  • Size: 39.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for audio_metrics-1.0.4.tar.gz
Algorithm Hash digest
SHA256 29a59f86a26603a405a2c800123d5ff0951234ce892cbd642d5eabaae41c469c
MD5 98540f093c82ac0cc2cadfa0fb2f0800
BLAKE2b-256 f9e47604367c4abced97e9f16635a8249b1d0b7f0ce0042bc91a9394f922a588

See more details on using hashes here.

Provenance

The following attestation bundles were made for audio_metrics-1.0.4.tar.gz:

Publisher: release.yml on SonyCSLParis/audio-metrics

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file audio_metrics-1.0.4-py3-none-any.whl.

File metadata

  • Download URL: audio_metrics-1.0.4-py3-none-any.whl
  • Upload date:
  • Size: 41.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for audio_metrics-1.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 24fbfc4f8ee0d262614fd2f97ffdc1a8afac5579dc0b8238635112f90723789c
MD5 e289c07d6207a0f8c4fde7837d55df14
BLAKE2b-256 25e33e3df2a125f74c38ba271e8451c6919299087c8dd07f5efa05834cfcd9a5

See more details on using hashes here.

Provenance

The following attestation bundles were made for audio_metrics-1.0.4-py3-none-any.whl:

Publisher: release.yml on SonyCSLParis/audio-metrics

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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