Skip to content

Latest commit

 

History

History
81 lines (56 loc) · 1.76 KB

README.md

File metadata and controls

81 lines (56 loc) · 1.76 KB

@tonaljs/scale-type npm version

tonal

@tonaljs/scale-type is a dictionary of musical scales.

Usage

ES6:

import { ScaleType } from "@tonaljs/tonal";

nodejs:

const { ScaleType } = require("@tonaljs/tonal");

API

get(name: string) => ScaleType

Given a scale type name, return a ScaleType object with the following properties:

  • name: the scale type name
  • aliases: a list of alternative names
  • quality: Major | Minor | Augmented | Diminished | Unknown
  • num: the pcset number
  • chroma: the pcset chroma
  • length: the number of notes
  • intervals: the interval list

Example:

ScaleType.get("major"); // =>
// {
// name: "major",
// aliases: ["ionian"],
// num: 2773,
// chroma: "101011010101",
// length: 7
// intervals: ["1P", "2M", "3M", "4P", "5P", "6M", "7M"],
// });

names() => string[]

Return a list of all scale names

all() => object[]

Return a list of all scale types

add(intervals: string[], name?: string, aliases?: string[]) => ScaleType

Add a scale type to dictionary:

ScaleType.add(["1P", "5P"], null, ["5"]);

HOW TO

How to get all pentatonics names?

ScaleType.all()
  .filter(scaleType => scaleType.length === 5)
  .map(scaleType => scaleType.name);

How do to add a scale to the dictionary?

ScaleType.add(["1P", "5P"], "quinta", ["quinta justa", "diapente"]);
ScaleType.scale("quinta"); // => { name: "quinta", intervals: ...}
ScaleType.scale("quinta justa"); // => { name: "quinta", intervals: ... }