Retrieve a scale based on a given mode and starting note. Information about these scales can be found on Wikipedia.
Currently supported scales:
- acoustic
- aeolian
- algerian
- super locrian
- augmented
- bebop dominant
- blues
- chromatic
- dorian
- double harmonic
- enigmatic
- flamenco
- romani
- half-diminished
- harmonic major
- harmonic minor
- hijaroshi
- hungarian minor
- hungarian major
- in
- insen
- ionian
- iwato
- locrian
- lydian augmented
- lydian
- locrian major
- pentatonic major
- melodic minor ascending
- melodic minor descending
- pentatonic minor
- mixolydian
- neapolitan major
- neapolitan minor
- octatonic c-d
- octatonic c-c#
- persian
- phrygian dominant
- phrygian
- prometheus
- harmonics
- tritone
- two-semitone tritone
- ukranian dorian
- whole-tone scale
- yo
Notes can be specified with either a name or a given number of semitones above middle C (C3). Octaves are done MIDI-style, so B2 is immediately followed by C3. Example notes:
Note("D")
the first D above middle CNote(2)
two semitones above middle C, which is the same asNote("D")
.
Notes have two fundamental properties:
.name
e.g."C"
.octave
e.g.3
You can retrieve both together MIDI style with:
.midi
e.g. "F#4"
You can add an integer to a note to raise it by that many semitones:
Note("C") + 12
the first C above middle C
musical_scales.scale("D")
# Defaults to major scale
# [D3, E3, F#3, G3, A3, B3, C#4, D4]
musical_scales.scale("F#", "blues")
# [F#3, A3, B3, C4, C#4, E4, F#4]
Detailed documentation can be found at readthedocs.io as well as in the docstrings of the python files themselves.
The source code is available under the MIT licence and can be found on Hector Miller-Bakewell's github.
This package was created as part of the QuTune Project.