A Python package for computing tonnes of melodic features found in computational musicology literature.
Project description
Melody-Features
Overview
This is a Python package designed to facilitate the use of many different melody analyis tools.
The main goal of this package is to consolidate a wide range of features from the computational melody analysis literature into a single place, in a single language.
This package is strictly for monophonic melodies - it will not compute any features for polyphonic music!
Included Contributions
Included in the package are contributions from:
- FANTASTIC (Müllensiefen, 2009)
- SIMILE (Müllensiefen & Frieler, 2006)
- melsim (Silas & Frieler, n.d.)
- jSymbolic2 (McKay & Fujinaga, 2006)
- IDyOM (Pearce, 2005)
- MIDI Toolbox (Eerola & Toiviainen, 2004)
Melody Features Summary
This package provides over 200 features from various computational melody analysis frameworks. For a comprehensive, interactive table with search and sorting capabilities, refer to:
The interactive table allows you to:
- Search features by name, implementation, or description
- Sort by any column (Name, Implementation, Type, etc.)
- Browse all features with detailed descriptions and references
Installation
# using pip
pip install melody-features
# or clone the repository
git clone https://github.com/dmwhyatt/melody-features.git
cd melody-features
# Install in development mode
pip install -e .
Quick Start
The feature set can be easily accessed using the top-level function get_all_features. Here's a basic example:
from melody_features import get_all_features
# Extract features from a directory of MIDI files, a single MIDI file
# or a list of paths to MIDI files
results = get_all_features(input="path/to/your/midi/files")
# Print the result of all feature calculations
print(results.iloc[:1,].to_json(indent=4, orient="records"))
By default, this function will produce a Pandas DataFrame containing the tabulated features, using the Essen Folksong Collection as the reference corpus.
This function can be customised in a number of ways, please see notebooks/example.ipynb for a detailed breakdown.
Melsim
Melsim is an R package for computing the similarity between two or more melodies. It is currently under development by Seb Silas and Klaus Frieler (https://github.com/sebsilas/melsim)
It is included with this feature set through a wrapper approach - take a look at example.py and the supplied MIDI files.
Since calculating similarities is highly modular in Melsim, we leave the user to decide how they wish to construct comparisons. Melsim is not run as part of the get_all_features function.
Available Corpora
The package comes with an example corpus, a MIDI conversion of the well-known Essen Folksong Collection (Eck, 2024; Schaffrath, 1995).
Development
Running Tests
# Run all tests
python tests/run_tests.py
# Run specific test suites
python -m pytest tests/test_module_setup.py -v
python -m pytest tests/test_corpus_import.py -v
python -m pytest tests/test_idyom_setup.py -v
Contributing
Contributions are welcomed, though this project is likely to be migrated into AMADS in the future...
See https://github.com/music-computing/amads
License
This project is licensed under the MIT License - see the LICENSE file for details.
Open-source code adapted from the Partitura Python package is licensed under the Apache-2.0 license, which can be found in the LICENSE-APACHE file. All credit for the original code found in pitch_spelling.py and tonal_tension.py remains with the original authors - we have not modified their functionality, we have simply adapted their code to be compatible with our codebase.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file melody_features-1.0.6.tar.gz.
File metadata
- Download URL: melody_features-1.0.6.tar.gz
- Upload date:
- Size: 1.0 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3e0dbff3d40472f8214ba46ee6cfc9ff6ae54c5bd7cb13eeaa10379707a5b87a
|
|
| MD5 |
09e7e9a0c2f29d79cfd71a002339ee46
|
|
| BLAKE2b-256 |
a528cb96f2311e0d937edbb4a8da1c2ef77a23cb971b70260516d00d6d6706e2
|
File details
Details for the file melody_features-1.0.6-py3-none-any.whl.
File metadata
- Download URL: melody_features-1.0.6-py3-none-any.whl
- Upload date:
- Size: 3.6 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2902d685b9be11a0d507aeaff83ca5ac14f698c3831359d56521f5f3f02f3f3b
|
|
| MD5 |
43c27e0baf0e0e8cd21fdb2937f94ee3
|
|
| BLAKE2b-256 |
35bf73345d79d37d4e3780d9959aac975057cc1c47662b96647af6bf7f338843
|