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.2.0.tar.gz
(11.5 kB
view hashes)
Built Distribution
pitchtypes-0.2.0-py3-none-any.whl
(23.0 kB
view hashes)
Close
Hashes for pitchtypes-0.2.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 259ef0fad2238e1c1e8849ef6223afa4ee19d0b76a1dac0288038a7c20f08f3d |
|
MD5 | d973702cfd05a2f28cf4e35fcafc98b2 |
|
BLAKE2b-256 | 171ee065a57cb854bbdc065a74c3fac0a5aa0a486bf90e609791591221507c3a |