Arduboy-homemade-package/board-package-source/libraries/ATMlib/README.md

116 lines
12 KiB
Markdown
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#ATMlib
ATMlib stands for **Arduboy Tracker Music** and is based on [_**Squawk**_](https://github.com/stg/Squawk "Squawk Github Page") a minimalistic 8-bit software synthesizer & playroutine library for Arduino, created by Davey Taylor aka STG.
While _Squawk_ provides a very nice synth, it wasn't optimized for a small footprint. Songs are not very efficient in size, so Joeri Gantois aka JO3RI asked Davey to help him work on a new songformat and so ATMlib was born.
Contributers:
* Davey Taylor - ATMsynth - Effects
* Joeri Gantois - Effects
### FILE/ARRAY FORMAT DESCRIPTION
|**Section** | **Field** | **Type** | **Description**
|--- | --- | ---------------- | ---
|**Track table** | | | **Number of tracks and their addresses**
| | Track count | UBYTE (8-bits) | Number of tracks in the file/array
| | Address track 1 | UWORD (16-bits) | Location in the file/array for track 1
| | … | … | …
| | Address track *__N__* | UWORD (16-bits) | Location in the file/array for track *__N__ (0 … 255)*
| | | |
|**Channel entry tracks** | | | **For each channel, track to start with**
| | Channel 0 track | UBYTE (8-bits) | Starting track index for channel 0
| | … | … | …
| | Channel 3 track | UBYTE (8-bits) | Starting track index for channel 3
| | | |
|**Track 0** | | | **Commands and parameters for track 0**
| | Command 0 | UBYTE (8-bits) | See command list
| | *and its* Parameters | none/variable | *See __parameter list__ for each command*
| | … | … | …
| | Command N | UBYTE (8-bits) |
| | *and its* Parameters | none/variable |
|**…** | **…** | **…** | **…**
|**Track _N_** | | | **Commands and parameters for track _N_** *(0-255)*
### COMMAND LIST
|**Command (_X_)** | **Parameter** | **Type** | **Description**
|--- | --- | ------------------ | ---
|**0<br/>0x00** | | | Stop playing
| | | |
|**1…63<br/>0x00+__X__** | note *(__X__)* | UBYTE (8-bits) | Start playing note *[__X__]* where 1 is a C1.<br/>See [Frequency to Tone](./extras/frequencyToTone.md "Frequency to Tone table")<br/>**_Note:_** everytime a note is played, volume is re-triggered
| | | |
|**64…159<br/>0x40…0x9F** | | | Configure effects (fx)
| | *See __fx list__* | none/variable | Effect is *[__X__ - 64]*
| | | |
|**160…223<br/>0x9F+__t__** | Ticks (*__t__*) | UBYTE (8-bits) | Delay for *[__X__ - 159]* or *[__t__]* ticks<br/>**_Note:_** delay of 0 does not exist and maximum is 64 ticks
| | | |
|**224, __Y__<br/>0xE0, __Y__** | Ticks (*__Y__*) | VLE (8/16-bits) | Long delay for *[__Y__ + 65]* ticks<br/> **_Note:_** LONG delay starts at 1 higher than SHORT delay
|  | | |
|**~~225…251~~** | | | ~~RESERVED~~
|  | | |
|**252, N<br/>0xFC, N** | Track *__N__* | UBYTE (8-bits) | Call/run/goto specified track<br/>Track index where *__N__* is the number of the track to go to
|  | | |
|**253, Y, N<br/>0xFD, Y, N** | | | Repeated call/run/goto specified track
| | Loop count (*__Y__*) | UBYTE (8-bits) | Repeat *[__Y__ + 1]* times (total)
| | Track *__N__* | UBYTE (8-bits) | Track index where *__N__* is the number of the track to go to
|  | | |
|**254<br/>0xFE** | | | Return/end of track marker
| | | |
|**255, L, D<br/>0xFF, L, D** | | | Binary data
| | Length *__L__* | VLE (8/16-bits) | Length in bytes of data to follow
| | Data *__D__* | variable | Binary data chunk (notify host application)
### FX LIST
|**Effect** | **Parameter** | **Type** | **Description**
|--- | ------------------------ | --------------------------- | ---
|**64+0<br/>64<br/>0x40** | set Volume (*__X__*) | UBYTE (8-bit) | Set volume to *[__X__]*.<br/>**_Note:_** If the combined volume of all channels<br/>exceed 255 there may be rollover distortion. This<br/>should not be disallowed, as it may be usesful as|<br/>an effects hack for the musician. There should<br/>however be a non-interfering warning when a<br/>musician enters a value above 63 for ch 1-3 or 32<br/>for ch 4 (noise). ch 4 the volume is counted double,<br/>so 32 is actually 64.
|**64+1<br/>65<br/>0x41** | slide Volume ON (*__X__*) | UBYTE (8-bit) | Slide the volume with an amount (positive or<br/>negative) of *[__X__]* for every tick.<br/>**_Note:_** This results in a fade-in or fade-out<br/>effect. There should be a non-|interfering warning<br/>when sliding would result in exceeding 63 for<br/>ch 1-3 and 32 for ch 4.
|**64+2<br/>66<br/>0x42** | slide Volume ON<br/>advanced (*__X__*) (*__Y__*) | UBYTE (8-bit)<br/>UBYTE (8-bit) | Slide the volume with an amount (positive or<br/>negative) of *[__X__]* for every [*__Y__*] ticks.<br/>*[__Y__]* includes 2 parameters: RRtttttt<br/>R = reserved and t = ticks.
|**64+3<br/>67<br/>0x43** | slide Volume OFF | | Stops the volume slide
|**64+4<br/>68<br/>0x44** | slide Frequency ON (*__X__*) | UBYTE (8-bit) | Slide the frequency with an amount (positive or<br/>negative) of *[__X__]* for every tick. <br/>**_Note:_** The amount of slide is limited<br/>between -127 to 127
|**64+5<br/>69<br/>0x45** | slide Frequency ON<br/>advanced (*__X__*) (*__Y__*) | UBYTE (8-bit)<br/>UBYTE (8-bit) | Slide the frequency with an amount (positive or<br/>negative) of *[__X__]* for every [*__Y__*] ticks.<br/>*[__Y__]* includes 2 parameters: RRtttttt<br/>R = reserved and t = ticks.
|**64+6<br/>70<br/>0x46** | slide Frequency OFF | | Stops the frequency slide
|**64+7<br/>71<br/>0x47** | set Arpeggio (*__X__*)(*__Y__*) | UBYTE (8-bit)<br/>UBYTE (8-bit) | Next to the current playing note, play a second<br/>and third note *[__X__]* for every *[__Y__]* ticks.<br/>*[__X__]* includes 2 parameters: AAAABBBB, where<br/>AAAA = base + amount to |second note and<br/>BBBB = second note + amount to third note.<br/>*[__Y__]* includes 4 parameters: FEDttttt,<br/>where F = reserved, E = toggle no third note,<br/>D = toggle retrigger, ttttt = tick amount.<br/>**_Note:_** Arpeggio is used for playing 3 notes<br/>out of a chord indivually
|**64+8<br/>72<br/>0x48** | Arpeggio OFF | | Stops the arpeggio
|**64+9<br/>73<br/>0x49** | SET Retriggering noise ON (*__X__*) | UBYTE (8-bit) | Noise channel consists of white noise. By setting<br/>retriggering *[__X__]* it swithes the entrypoint at<br/>a given speed. *[__X__]* includes 2 parameters:<br/>AAAAAABB , where AAAAAA |= entry point and<br/>BB = speed (0 = fastest, 1 = faster , 2 = fast)
|**64+10<br/>74<br/>0x4A** | Retriggering noise OFF | | Stops the retriggering for the noise on channel 3
|**64+11<br/>75<br/>0x4B** | add Transposition (*__X__*) | UBYTE (8-bit) | Shifts the played notes by adding *[__X__]* to<br/>the existing transposition for all playing notes.<br/>**_Note:_** The amount of shift is limited<br/>between -127 to 127. However there |should be<br/>a non-interfering warning when transposing would<br/>result in exceeding 63 or get lower than 0
|**64+12<br/>76<br/>0x4C** | set Transposition (*__X__*) | UBYTE (8-bit) | Shifts the played notes by setting the transposition<br/>to [__X__]* for all playing notes.<br/>**_Note:_** The amount of shift is limited<br/>between -127 to 127. However there should |be a<br/>non-interfering warning when transposing would<br/>result in exceeding 63 or get lower than 0
|**64+13<br/>77<br/>0x4D** | Transposition OFF | | Stops the transposition
|**64+14<br/>78<br/>0x4E** | set Tremolo (*__X__*)(*__Y__*) | UBYTE (8-bit)<br/>UBYTE (8-bit) | *[__X__]* sets Depth.<br/>*[__Y__]* includes 4 parameters<br/>RxxBBBBB R = Retrig, x = reserved , B = rate<br/>**_Note:_** Tremolo and Vibrato can **NOT**<br/>be combined in the same |stack
|**64+15<br/>79<br/>0x4F** | Tremolo OFF | | Stops the tremolo
|**64+16<br/>80<br/>0x50** | set Vibrato (*__X__*)(*__Y__*) | UBYTE (8-bit)<br/>UBYTE (8-bit) | *[__X__]* sets Depth.<br/>*[__Y__]* includes 4 parameters<br/>RxxBBBBB R = Retrig, x = reserved , B = rate<br/>**_Note:_** Tremolo and Vibrato can **NOT**<br/>be combined in the same |stack
|**64+17<br/>81<br/>0x51** | Vibrato OFF | | Stops the vibrato
|**64+18<br/>82<br/>0x52** | SET Glissando (*__X__*) | UBYTE (8-bit) | *[__X__]* includes 2 parameters: Vttttttt<br/>V = value ( 0 = go 1 note up, 1 = go 1 note down)<br/>and t = amount of ticks, between each step
|**64+19<br/>83<br/>0x53** | Glissando OFF | | Stops the Glissando
|**64+20<br/>84<br/>0x54** | SET Note Cut (*__X__*) | UBYTE (8-bit) | *[__X__]* sets the equal amount of ticks<br/>between note ON and OFF
|**64+21<br/>85<br/>0x55** | Note Cut OFF | | Stops the Note Cut
|**…** | **…** | **…** | **…**
|**64+92<br/>156<br/>0x9C** | ADD song tempo (*__X__*) | UBYTE (8-bit) | adds *[__X__]* to the tempo of the song.<br/>Total value should be between 0 - 127<br/>**_Note:_** the higher the tempo to more CPU it takes.
|**64+93<br/>157<br/>0x9D** | SET song tempo (*__X__*) | UBYTE (8-bit) | (re-)sets *[__X__]* as the tempo of the song.<br/>Standard is 25. Value should be between 0 - 127<br/>**_Note:_** the higher the tempo to more CPU it takes.
|**64+94<br/>158<br/>0x9E** | GOTO advanced<br/><br/>(*__W__*)<br/>(*__X__*)<br/>(*__Y__*)<br/>(*__Z__*) | <br/><br/>UBYTE (8-bit)<br/>UBYTE (8-bit)<br/>UBYTE (8-bit)<br/>UBYTE (8-bit) | **_Note:_** handy command for having an intro<br/>and a repeating song part<br/>For channel __0__ go to track __W__<br/>For channel __1__ go to track __X__<br/>For channel __2__ go to track __Y__<br/>For channel __3__ go to track __Z__
|**64+95<br/>159<br/>0x9F** | STOP current channel | | channel is no longer being processed<br/>**_Note:_** if all channels have reached STOP, the song ends
|~~TBD~~ | ~~TBD~~ | ~~TBD~~ | ~~TBD~~
#### Thoughts on effects:
**Note:** These are the primitives to be implemented in the playroutine effects processor. Most will have several effect command numbers associated with them for various aspects of the same primitive. Effects can be combined but not stacked, but some combinations may have undesired/interesting interference.
* Volume slide: a gradual increasing or decreasing of the volume.
* Frequency slide: a gradual increasing or decreasing of the [frequency](https://en.wikipedia.org/wiki/Frequency "frequency wikipedia").
* Arpeggio: a group of [notes](https://en.wikipedia.org/wiki/Musical_note "note wikipedia") which are rapidly and automatically played one after the other.
* Retriggering (on [note](https://en.wikipedia.org/wiki/Musical_note "note wikipedia") or by automation): oscillators are restarted either automatically or at the start of each new note.
* Transposition (also for microtonals): play [notes](https://en.wikipedia.org/wiki/Musical_note "note wikipedia") in a different key, or fine tune notes to provide microtonals; frequencies that are in between notes.
* Tremolo: a slight, rapid and regular fluctuation in the amplitude/volume of a [note](https://en.wikipedia.org/wiki/Musical_note "note wikipedia").
* Vibrato: a slight, rapid and regular fluctuation in the [pitch](https://en.wikipedia.org/wiki/Pitch_(music) "pitch wikipedia") of a [note](https://en.wikipedia.org/wiki/Musical_note "note wikipedia").
* Glissando: controls if and how a gradual frequency slide "snaps" to adjacent notes.
* Note cut (with delay and automation): provides a method to stutter and adjust note timing.