Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jangler/faunatone

Tracker-style microtonal MIDI sequencer
https://github.com/jangler/faunatone

microtonality midi music

Last synced: 27 days ago
JSON representation

Tracker-style microtonal MIDI sequencer

Awesome Lists containing this project

README

        

# Faunatone

A tracker-style microtonal MIDI sequencer. Since MIDI does not have any
widely-implemented native support for microtonality, Faunatone uses pitch
bending to play non-12edo pitches. The tradeoff is that in this model, you
cannot generally have more than 15-voice melodic polyphony without experiencing
artifacts, although GM 1 only guarantees 16 melodic voices anyway.

Management of individual output MIDI channels by the user is not required;
Faunatone operates in terms of virtual channels which it maps dynamically by
default.

![Screenshot](screenshot.png?raw=true)

## Features

- First-class support for various approaches to microtonality
- MIDI input, output, and export including support for all GM 1 channel events
- Remap keyboard and MIDI note input (intervals and layout)
- Control how pitches are notated
- Free transposition and modulation (with notation caveats)
- Define and use accidentals to modify pitches
- Flexible rhythms via freely variable beat division
- Import Scala scale files

## Download

Prebuilt standalone binaries for Windows and Linux are available from
[the releases page](https://github.com/jangler/faunatone/releases).

## Differences from other trackers

If you are familiar with tracker interfaces (Renoise, OpenMPT, SunVox, etc),
you will probably not have trouble picking up Faunatone. If you are *not*
familiar with tracker interfaces, then maybe find a tutorial somewhere?
Faunatone does make a few significant departures from "conventional" trackers:

1. There are no "rows"; beats can be divided into arbitrarily many equal
divisions, and events are placed with MIDI tick precision (in this case, 960
ticks per beat). The beat division can be adjusted on the fly using menus
or keyboard shortcuts; this only affects the cursor's behavior and does not
change the timing of any events that were already placed.
2. There are no "columns", only "tracks" that can each contain any type of event.
Multiple tracks can be associated with the same virtual "channel" such that
ex. a controller change in a track labeled "channel 1" will affect all
tracks with that label.
3. There are no "patterns"; a song is one continuous sequence of events.
4. As in most trackers, the mapping of keys to intervals/pitches defaults to
12edo, but this is completely configurable and the mapping can be changed at
any time. Pitches that don't have names in the current mapping are displayed
numerically instead of symbolically.

Also, percussion notes are entered by holding the Shift key. The keymap for
percussion notes is separate from the keymap for melodic notes.

## File format

Faunatone save files (\*.faun) are zlib-compressed JSON.

## Further documentation

- [usage.md](https://github.com/jangler/faunatone/blob/master/docs/usage.md):
general usage guide
- [commands.md](https://github.com/jangler/faunatone/blob/master/docs/commands.md):
menu commands
- [keymaps.md](https://github.com/jangler/faunatone/blob/master/docs/keymaps.md):
note input mapping and notation
- [config.md](https://github.com/jangler/faunatone/blob/master/docs/config.md):
other configuration files
- [building.md](https://github.com/jangler/faunatone/blob/master/docs/building.md):
building from source

## Music written in Faunatone

- [jangler - acrylic warp](https://jangler.bandcamp.com/album/acrylic-warp)
- [jangler - web world / nonexclusivity](https://soundcloud.com/janglerr/sets/web-world-nonexclusivity)
- [Chimeratio & jangler - tunnel7_r35b](https://sexytoadsandfrogsfriendcircle.bandcamp.com/track/tunnel7-r35b)
- [jangler - extra vaganza](https://jangler.bandcamp.com/album/extra-vaganza)