musically meaningful pitch types
Project description
pitchtypes
Musically meaningful types
The purpose of this Python library is to:
- Provide types that handle pitch in a musically correct way.
- Make it easy to implement other musically meaningful types.
For instance, spelled pitch is handled correctly:
>>> from pitchtypes import SpelledPitchClass
>>> p1 = SpelledPitchClass("C#")
>>> p2 = SpelledPitchClass("Gb")
>>> i = p1 - p2
>>> type(i)
<class 'pitchtypes.datatypes.SpelledIntervalClass'>
>>> i
+AA4
Of course, you can also convert spelled pitches to their enharmonic equivalents:
>>> from pitchtypes import SpelledPitch, EnharmonicPitch
>>> spelled = SpelledPitch("C#4")
>>> enharmonic = spelled.convert_to(EnharmonicPitch)
>>> type(enharmonic)
<class 'pitchtypes.datatypes.EnharmonicPitch'>
>>> enharmonic.midi
61
>>> enharmonic.name('sharp')
C#4
>>> enharmonic.name('flat')
Db4
And used continuous log-frequency space (assuming twelve-tone equal temperament for enharmonic pitch):
>>> from pitchtypes import EnharmonicPitch, LogFreqPitch
>>> enharmonic = EnharmonicPitch("A4")
>>> logfreq = enharmonic.convert_to(LogFreqPitch)
>>> logfreq
440.Hz
For more examples, have a look at the Tutorial.ipynb!
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
pitchtypes-0.0.3.tar.gz
(10.1 kB
view hashes)
Built Distribution
pitchtypes-0.0.3-py3-none-any.whl
(21.7 kB
view hashes)
Close
Hashes for pitchtypes-0.0.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 381fdd40b5af517813c0b526525bf17b3d86c85146e77d3848072dc204fdc4b7 |
|
MD5 | 71824e081f651faa21482fed8ef780b5 |
|
BLAKE2b-256 | 9e9290d796e278081d133e215b80b7d85df2cc9e8e3172d8b2ca7f9fec5b2782 |