ES6:
import { Chord } from "tonal";
Nodejs:
const { Chord } = require("tonal");
Get the chord properties from a chord type and an (optional) tonic and (optional) root. Notice that the tonic must be present if the root is present. Also the root must be part of the chord notes.
It returns the same object that ChordType.get
but with additional properties:
- symbol: the chord symbol (a combiation of the tonic, chord type shortname and root, if present). For example:
Cmaj7
,Db7b5/F
. The symbol always uses pitch classes (note names without octaves) for both the tonic and root. - tonic: the tonic of the chord (or an empty string if not present)
- root: the root of the chord (or an empty string if not present)
- rootDegree: the degree of the root. 0 if root not present. A number greater than 0 if present, where 1 indicates the tonic, 2 the second note (normally the 3th), 2 the third note (normally the 5th), etc.
- notes: an array of notes, or empty array if tonic is not present. If the root is pres
Example:
Chord.getChord("maj7", "G4", "B4"); // =>
// {
// empty: false,
// name: "G major seventh over B",
// symbol: "Gmaj7/B",
// tonic: "G4",
// root: "B4",
// rootDegree: 2,
// setNum: 2193,
// type: "major seventh",
// aliases: ["maj7", "Δ", "ma7", "M7", "Maj7"],
// chroma: "100010010001",
// intervals: ["3M", "5P", "7M", "8P"],
// normalized: "100010010001",
// notes: ["B4", "D5", "F#5", "G5"],
// quality: "Major",
// }
An alias of Chord.getChord
but accepts a chord symbol as parameter.
Chord.get("Cmaj7");
// same as
Chord.get(["C", "maj7"]);
// same as
Chord.getChord("maj7", "C");
Important: currently chord with bass are NOT allowed (will be implemented in next version):
Chord.get("Cmaj7/E"); // => { empty: true }
Scale.degrees
returns a function to get a note name from a scale degree:
const c4m7 = Chord.degrees(["C4", "m7");
c4m7(1); // => "C4"
c4m7(2); // => "Eb4"
c4m7(3); // => "G4"
c4m7(4); // => "Bb4"
c4m7(1); // => "C5"
It can be used to find chord inversions:
[1, 2, 3, 4].map(chord); // => ["C4", "Eb4", "G4", "Bb4"]
[2, 3, 4, 5].map(chord); // => ["Eb4", "G4", "Bb4", "C5"]
[3, 4, 5, 6].map(chord); // => ["G4", "Bb4", "C5", "Eb5"]
[4, 5, 6, 7].map(chord); // => ["Bb4", "C5", "Eb5", "G5"]
Bear in mind that degree numbers starts with 1 and 0 returns an empty string:
c4m7(0); // => ""
See Scale.degrees
Same as Chord.degrees
but 0 is the tonic. Plays better with numeric ranges:
import { Range, Chord } from "tonal";
Range.numeric([-3, 3]).map(Chord.steps(["C4", "aug"]));
// => ["G#3", "E3", "C3", "C4", "E4", "G#4", "C5"]
Given a list of notes, get the possible chord names:
Chord.detect(["D", "F#", "A", "C"]); // => ["D7"]
Chord.detect(["F#", "A", "C", "D"]); // => ["D7/F#"]
Read more at chord-detect
Transpose a chord symbol by an interval:
Chord.transpose("Eb7b9", "5P"); // => "Bb7b9"
Get all scales where the given chord fits:
Chord.chordScales("C7b9");
// => ["phrygian dominant", "flamenco", "spanish heptatonic", "half-whole diminished", "chromatic"]
Get all chords names that are a superset of the given one (has the same notes and at least one more)
Chord.extended("Cmaj7");
// => [ 'Cmaj#4', 'Cmaj7#9#11', 'Cmaj9', 'CM7add13', 'Cmaj13', 'Cmaj9#11', 'CM13#11', 'CM7b9' ]
Find all chords names that are a subset of the given one (less notes but all from the given chord)
Chord.reduced("Cmaj7"); // => ["C5", "CM"]