Skip to main content

Utilities to work with pitches, convert between midinotes, frequency and notenames

Project description

pitchtools provides a set of functions to work with musical pitches.

Features

  • convert between frequencies, midinotes and notenames

  • microtones are fully supported

  • split a pitch into its multiple components (pitch class, octave, microtonal deviation, etc.)

  • transpose a pitch taking its spelling into consideration

  • create custom pitch converters to work with custom reference frequencies, or modify the reference frequency globally

Documentation

https://pitchtools.readthedocs.io/en/latest/

Examples

Convert some note names to frequencies

>>> from pitchtools import *
>>> eflat_scale = "4Eb 4F 4G 4Ab 4Bb 5C 5D".split()
>>> for note in eflat_scale:
...     # convert notename to frequency using the default reference frequency (442 Hz)
...     freq = n2f(note)
...     # convert frequency to midi
...     midinote = f2m(freq)
...     print(f"{note} = {freq:.1f}Hz (midi = {midinote})")
4Eb = 312.5 Hz (midi = 63.0)
4F  = 350.8 Hz (midi = 65.0)
4G  = 393.7 Hz (midi = 67.0)
4Ab = 417.2 Hz (midi = 68.0)
4Bb = 468.3 Hz (midi = 70.0)
5C  = 525.6 Hz (midi = 72.0)
5D  = 590.0 Hz (midi = 74.0)

The same but with a different reference frequency

from pitchtools import *
ebscale = "4Eb 4F 4G 4Ab 4Bb 5C 5D".split()
cnv = PitchConverter(a4=435)
for note in ebscale:
    # Convert to frequency with default a4=442 Hz
    freq = cnv.n2f(note)
    midinote = cnv.[Of2m(freq)
    print(f"{note} = {freq} Hz (midinote = {midinote})")

Microtones

Microtones are fully supported, either as fractional midinotes or as notenames.

>>> from pitchtools import *
>>> n2m("4C+")
60.5
>>> n2m("4Db-10")
60.9
>>> m2n(61.2)
4C#+20

Microtonal notation

Midinote

Notename

60.25

4C+25 / 4C>

60.45

4C+45

60.5

4C

60.75

4Db-25

61.5

4D-

61.80

4D-20

63

4D#

63.5

4D#+

63.7

4E-30


Installation

pip install pitchtools

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

pitchtools-1.17.1.tar.gz (27.5 kB view details)

Uploaded Source

Built Distribution

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

pitchtools-1.17.1-py3-none-any.whl (20.7 kB view details)

Uploaded Python 3

File details

Details for the file pitchtools-1.17.1.tar.gz.

File metadata

  • Download URL: pitchtools-1.17.1.tar.gz
  • Upload date:
  • Size: 27.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.22

File hashes

Hashes for pitchtools-1.17.1.tar.gz
Algorithm Hash digest
SHA256 2fdec54b909bb974f6c89cf4ca3fdb5087122f74be5aefe98b1df4322e302887
MD5 e33c10b05076fd19a27c112733996dca
BLAKE2b-256 c3dd29e5e6a07b146e3fc152dc682136f2ec2d563e9bce2b096c2d5b765e9e67

See more details on using hashes here.

File details

Details for the file pitchtools-1.17.1-py3-none-any.whl.

File metadata

File hashes

Hashes for pitchtools-1.17.1-py3-none-any.whl
Algorithm Hash digest
SHA256 43b18b842d01dcc40f89c604d5f71a73a1f5dfd26b48f214134b7d7871414c98
MD5 243750709a04adbc415ef3331473ee66
BLAKE2b-256 73ad18db03289210ebfb5787cfd903ab96868206cb415501212ee0319c18f082

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