Skip to main content

Network transition chord progressions

Project description

Python Chord Progression Network

Network transition chord progression generator

DESCRIPTION

This class generates network transition chord progressions. The transitions are given by a net of scale positions, and the chord "flavors" are defined by a chord_map of types. The chords that are returned are either named chords or lists of three or more named notes with octaves.

The chord types are as follows:

'' (i.e. an empty string) means a major chord.
'm' signifies a minor chord.
'7' is a seventh chord and 'M7' is a major 7th chord.
'dim' is a diminished chord and 'aug' is augmented.
'9', '11', and '13' are extended 7th chords.
'M9', 'M11', and 'M13' are extended major-7th chords.
'm9', 'm11', and 'm13' are extended minor-7th chords.

For the major scale (ionian mode), this chord_map is ['', 'm', 'm', '', '', 'm', 'dim']. The dorian mode is ['m', 'm', '', '', 'm', 'dim', '']. A chromatic scale is all minors. This can be set in the constructor, or seen by printing it after Generator construction.

The tonic attribute means that if the first chord of the progression is being generated, then for 0 choose a random successor of the first chord, as defined by the net attribute. For 1, return the first chord in the scale. For any other value, choose a random value of the entire scale.

The resolve attribute means that if the last progression chord is being generated, then for 0 choose a random successor. As for the tonic, for 1, return the first chord in the scale, and for any other value, choose a random value of the entire scale. In all other cases (i.e. the middle chords of the progression), choose a random successor.

By default, all chords and notes with accidentals are returned as sharps. If you want flats, set the flat attribute to True in the constructor.

If the substitute attribute is set to True, then the progression chords are subject to extended, "jazz" chord, including tritone substitution. For now, for this work-in-progress advanced option, please see the substitution() method in the source...

SYNOPSIS

from chord_progression_network import Generator

g = Generator( # defaults
    max=8,
    scale_note='C',
    scale_name='major',
    octave=4,
    net={
        1: [1, 2, 3, 4, 5, 6],
        2: [3, 4, 5],
        3: [1, 2, 4, 6],
        4: [1, 3, 5, 6],
        5: [1, 4, 6],
        6: [1, 2, 4, 5],
        7: [],
    },
    chord_map=[ '', 'm', 'm', '', '', 'm', 'dim' ],
    tonic=1,
    resolve=1,
    flat=False,
    chord_phrase=False,
    substitute=False,
    verbose=False,
)
phrase = g.generate()

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

chord_progression_network-0.1.0.tar.gz (43.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

chord_progression_network-0.1.0-py3-none-any.whl (29.9 kB view details)

Uploaded Python 3

File details

Details for the file chord_progression_network-0.1.0.tar.gz.

File metadata

File hashes

Hashes for chord_progression_network-0.1.0.tar.gz
Algorithm Hash digest
SHA256 0af6b76939297332962029d18b490ed47529ab13acfe7c1074f9a8066a9fa8bf
MD5 1a16e721efa33038c7f6ee64d0d7bd22
BLAKE2b-256 a440a812872735118ccf8b78b4d55b25a6e555d21588afd077f0da570712910e

See more details on using hashes here.

File details

Details for the file chord_progression_network-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for chord_progression_network-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 463b7665e611af83b267795f826e603b6331a4bba47d5d39fe27b341478a7c31
MD5 fbde225ecb095933230cb53bc0cc94f1
BLAKE2b-256 ed681650cf00f94a720c476450f4d8785c7ab9b28b1d1e01e2021e71722af974

See more details on using hashes here.

Supported by

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