Skip to content

Latest commit

 

History

History
24 lines (15 loc) · 2.17 KB

README.md

File metadata and controls

24 lines (15 loc) · 2.17 KB

pitch-classes

pitch-classes is a library intended to aid in the exploration of different equally-tempered musical tuning systems. It has five classes—PitchClassSet, PitchClassSequence, IntervalVector, IntervalSequence, and SetSequence—as well as several functions for generating objects. Each of these classes works with any integer "pitch class universe" size greater than 1, i.e. any equal temperament.

PitchClassSet

A PitchClassSet is a set of pitch classes, that is, a collection of pitches without regard for octave or ordering.

PitchClassSets have methods for transforming themselves in-place—.transpose(), .invert(), and so on—as well as methods for creating new PitchClassSets—.transposed(), .inverted(), etc.

PitchClassSets support many of the same methods as Python sets, including comparisons such as <, >, == and so on, and operations such as &, |, ^ and -. When PitchClassSets of different sizes of universe are compared, the objects are scaled to the same size of universe to allow for comparison (for example, an augmented triad is equal to an augmented triad, no matter whether it is expressed in 12-tone equal temperament or 3-tone equal temperament).

PitchClassSequence

A PitchClassSequence is a sequence of pitch classes, that is, a collection of pitches without regard for octave. Like PitchClassSets, PitchClassSequences have methods for in-place transformation and the creation of new PitchClassSets.

PitchClassSequences support some of the operations as Python sets, such as adding, appending and extending.

IntervalVector

An IntervalVector represents the intervals between the pitch classes of a PitchClassSet, familiar from the analysis of 12-tone music. It has no methods.

IntervalSequence

An IntervalSequence represents a series of intervals between successive pitch classes in a PitchClassSequence. It includes methods for inverting, retrograding and changing of universe size, as well as a method .melody() for creating a PitchClassSequence from a given IntervalSequence.

SetSequence

A SetSequence is a sequence of PitchClassSets representing, for example, a succession of chords.