Skip to main content

Extreme-fidelity synthesis of musical elements, based on the MASS framework

Project description

Music

Music is a python package to generate and manipulate music and sounds. It's written using the MASS (Music and Audio in Sample Sequences) framework, a collection of psychophysical descriptions of musical elements in LPCM audio through equations and corresponding Python routines.

To have a further understanding of the routines you can read the article Musical elements in the discrete-time representation of sound.

If you use this package, please cite the forementioned article.

Core features

The precision of Music makes it the perfect choice for many scientific uses. At its core there are a few important features:

  • Sample-based synth, meaning that the state is updated at each sample. For example, when we have a note with a vibrato, each sample is associated to a different frequency. By doing this the synthesized sound is the closest it can be to the mathematical model that describes it.
  • Musical structures with emphasis in symmetry and discourse.
  • Speech and singing interfaces available to synthesize voices.

Music can be used alone or with other packages, and it's ideal for audiovisualization of data. For example, it can be used with Percolation and Participation for harnessing open linked social data, or with audiovisual analytics vocabulary and ontology (AAVO).

How to install

To install music you can either install it directly with pip:

pip3 install music

or you can clone this repository and install it from there:

git clone https://github.com/ttm/music.git
pip3 install -e <path_to_repo>

This install method is especially useful when reloading the modified module in subsequent runs of music, and for greater control of customization, hacking and debugging.

Dependencies

Every dependency is installed by default by pip, but you can take a look at requirements.txt.

To use the singing interface you'll also nead eSpeak, SoX, and abcMIDI, while MIDI.pm and FFT.pm are needed by eCantorix to synthesize singing sequences.

Linux

On Ubuntu everything can be installed with:

sudo apt install espeak sox abcmidi
sudo cpan install MIDI
sudo cpan install Math::FFT

macOS

On macOS you can first install Homebrew, and then:

brew install espeak sox abcmidi perl
cpan install MIDI
cpan install Math::FFT

Examples

Inside the examples folder you can find some scripts that use the main features of Music.

Package structure

The modules are:

  • core:
    • synths for synthesization of notes (including vibratos, glissandos, etc.), noises and envelopes.
    • filters for the application of filters such as ADSR envelopes, fades, IIR and FIR, reverb, loudness, and localization.
    • io for reading and writing WAV files, both mono and stereo.
    • functions for normalization.
  • structures for higher level musical structures such as permutations (and related to algebraic groups and change ringing peals), scales, chords, counterpoint, tunings, etc.
  • singing for singing with eCantorix. While it's not properly documented, and it might need some tweaks, it's working. Speech is currently achieved through espeak in the most obvious way, using os.system as in:
  • legacy for musical pieces that are rendered with the Music package and might be used as material to make more music.
  • tables for the generation of lookup tables for some basic waveform.
  • utils for various functions regarding conversions, mix, etc.

Roadmap

Music is stable but still very young. We didn't have the opportunity yet to make Music all we want it to be.

Here is one example of what we're aiming at:

import music

music.render_demos() # render some wav files in ./

music.legacy.experiments.cristal2(.2, 300) # wav of sonic structure in ./

sound_waves = music.legacy.songs.madame_z(render=False) # return numpy array

sound_waves2 = music.core.io.open("demosong2.wav") # numpy array

music = music.remix(sound_waves, soundwaves2)
music_ = music.horizontal_stack(sound_waves[:44100*2], music[len(music)/2::2])

music.core.io.write_wav_mono(music_)

Coding conventions

The code follows PEP 8 conventions.

For a better understanding of each function, the math behind it and see examples of their use, you can read their docstring.

Further information

Music is primarily intended for artistic use, but was also designed to run psychophysics experiments and data sonification.

You can find an example in Versinus, an animated visualization method for evolving networks that uses Music to render the musical track that represents networks structures.

:::

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

music-1.0.0b5.tar.gz (51.2 kB view details)

Uploaded Source

Built Distribution

music-1.0.0b5-py3-none-any.whl (61.2 kB view details)

Uploaded Python 3

File details

Details for the file music-1.0.0b5.tar.gz.

File metadata

  • Download URL: music-1.0.0b5.tar.gz
  • Upload date:
  • Size: 51.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.13

File hashes

Hashes for music-1.0.0b5.tar.gz
Algorithm Hash digest
SHA256 68c4d4651dbf743901653f3e58abd738fe64cbc7cacaf683f67521d7752a68f4
MD5 255013d831ba14b920817b55be776453
BLAKE2b-256 5d6c1ec7f2fbf29160a1f91c144762be1f93d2b7b8cbbb429144521714707a34

See more details on using hashes here.

File details

Details for the file music-1.0.0b5-py3-none-any.whl.

File metadata

  • Download URL: music-1.0.0b5-py3-none-any.whl
  • Upload date:
  • Size: 61.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.13

File hashes

Hashes for music-1.0.0b5-py3-none-any.whl
Algorithm Hash digest
SHA256 5f8f814d942b2f3350d8797a977bf3802d5fcd5fb409796d721c526138cc2d32
MD5 eae0f341728218092bee06e6dccdaed5
BLAKE2b-256 2db95215479b532b5e4a30f07b64d74f4b8c54b6ea227826d2abbd2a667f6155

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page