OpenScofo is an open-source score-following system specifically designed for contemporary music.
Project description
OpenScofo
OpenScofo: OpenScore Follower
OpenScofo is an open-source project designed to provide score following capabilities for contemporary music applications. Originally developed as a PureData (Pd) object, OpenScofo has now been expanded into a versatile C++ library that integrates seamlessly with multiple environments, including a Max Object, Python package, and others comming. Currently under development, OpenScofo is already functional and serves as a valuable tool for researchers and musicians.
Download
- Check the Releases Page.
Examples
- Cânticos de Silício by Charles K. Neimog;
- BWV-1013 by Bach;
Goal
The aim of OpenScofo is to provide a straightforward and accessible tool for real-time score following. By keeping the software lightweight, it can run seamlessly on the web through the pd4web platform, thanks to the ability to use PureData directly in web browsers. With pd4web and OpenScofo will be possible to use the software in rehearsals with just a single click, eliminating the need for external libraries, compatibility issues, or complex installations -- ultimately facilitating the sharing and performance of contemporary music.
Collaboration and Contribution
I invite composers, researchers and developers to contribute to the OpenScofo project. Not just with code, but with theory, math, etc. I am trying to make OpenScofo acessible via a Python implementation, to test it should be easy. By sharing the source code, I am trying to provide access to the theories and mathematical formulas that drive the software, all this come from the amazing research work of Arshia Cont and Philippe Cuvillier at IRCAM.
Technical Foundations
OpenScofo uses several concepts developed by many researches (with focus on the research of Cont and Cuvillier).
- Pitch Comparison: Utilizes the Kullback-Leibler (KL) Divergence method for pitch comparison as presented by Christopher Raphael (2006), Arshia Cont in 2008 and 2010.
- Rhythm Synchronization: Integrates theories of rhythm synchronization developed by Edward Large and Mari Riess Jones (1999) and Edward Large and Caroline Palmer (2002), as presented for Cont (2010).
- Forward Algorithm: For now, OpenScofo uses the equation presented by Arshia Cont (2010) and developed by Yann Guédon (2005).
- Score Language: Based on the
scofo(by Miller Puckette) andantescofo~(by Arshia Cont, Philippe Cuvillier, and others) language.
Building
Requirements
- On Windows, you need
mingw64.
Optional
- treesitter (
npm install tree-sitter) (If you want to change/update score syntax). - pybind11 (optional): To build Python package.
- PureData (optional): To build the Pd Object.
Building Options
-
BUILD_ALL: Build all OpenScofo modules (Python, Pd, Max). -
BUILD_ALL_OBJECTS: Build Pd and Max Objects. -
BUILD_PY_MODULE: Build or not the OpenScofo python module. -
BUILD_PD_OBJECT: Build or not the Pd Object. -
BUILD_MAX_OBJECT: Build or not the Max Object. -
PDLIBDIR: Where the Pd object will be installed.
Building Steps
git clone https://github.com/charlesneimog/OpenScofo --recursive
cmake . -B build -DBUILD_ALL_OBJECTS=ON -G Ninja
cmake --build build
To install use cmake --install build.
GPLv3 Licensing Notice
OpenScofo is distributed under the GNU General Public License version 3 (GPLv3).
The GPLv3 is a free and open source license. Any software that incorporates, links to (including dynamically), or forms a combined work with OpenScofo and is distributed must also be licensed under the GPLv3, with its complete corresponding source code made available.
Non-compliance automatically terminates the license rights granted under the GPLv3 and may constitute copyright infringement.
Full license text: https://www.gnu.org/licenses/gpl-3.0.html
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 Distributions
Built Distributions
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 openscofo-0.1.7a4-cp38-abi3-win_amd64.whl.
File metadata
- Download URL: openscofo-0.1.7a4-cp38-abi3-win_amd64.whl
- Upload date:
- Size: 4.2 MB
- Tags: CPython 3.8+, Windows x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
54cc8f45d70dd122e40c8d7036c3679dec4002f2a3f51fad2186f43c6e9e1be9
|
|
| MD5 |
88bc4e0bfa9aba744d74f963bef23315
|
|
| BLAKE2b-256 |
7b3b0c64741a975681b3ce82344a03480125cbf9b557eaaa5340e03c573d7657
|
File details
Details for the file openscofo-0.1.7a4-cp38-abi3-manylinux_2_39_x86_64.whl.
File metadata
- Download URL: openscofo-0.1.7a4-cp38-abi3-manylinux_2_39_x86_64.whl
- Upload date:
- Size: 4.4 MB
- Tags: CPython 3.8+, manylinux: glibc 2.39+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b5a17b6c3a1c670dbc3f389b03c414986b0caca9fb9820e30eb8e408f3986124
|
|
| MD5 |
d805df96a25b2283b74f72616646fce6
|
|
| BLAKE2b-256 |
eec7baefb8d4d0497c388bd2c9529fe544229eea6df303112235004ab690275f
|
File details
Details for the file openscofo-0.1.7a4-cp38-abi3-macosx_15_0_arm64.whl.
File metadata
- Download URL: openscofo-0.1.7a4-cp38-abi3-macosx_15_0_arm64.whl
- Upload date:
- Size: 5.3 MB
- Tags: CPython 3.8+, macOS 15.0+ ARM64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7125306bd8c98d69b4d44cc03b13e0efabc4dddd5254b68174392560ef42269f
|
|
| MD5 |
c0cd6e4d4453e4b6fbfcc3fc923a3e74
|
|
| BLAKE2b-256 |
a8c0792b701b3519e817e4a9ad9f8c9c40742061bd8fbebbe65038c1fd57bca7
|