Skip to contents

What are effect commands

A pattern table is composed of cells telling the tracker which notes to play in which order. It also has a field for effect commands. It is often represented as a three digit hexadecimal value. The first hex digit represents the effect command, the latter represent parameter values used by the command. The table below summarises all available effects in ProTracker.

Code Effect Description
0xy Arpeggio This effect alternates the pitch each tick to simulate a chord. xy needs to be greater than 00. First the specified note is played, then the pitch is increased with x semitones, then with y semitones.
1xy Porta up Decrease the period value with xy every tick but the first.
2xy Porta down Increase the period value with xy every tick but the first.
3xy Porta to note Change the period value with xy every tick but the first, untill the specified target note is reached.
4xy Vibrato Oscillate the pitch with magnitude x. Where y relates to the oscillation frequency.
5xy Porta to note + Volume slide A combination of porta to note (3xy) and volume slide (Axy).
6xy Vibrato + Volume slide A combination of vibrato (4xy) and volume slide (Axy).
7xy Tremolo Oscillate the volume with magnitude x. Where y relates to the oscillation frequency.
8xy Not implemented This effect command is not implemented in ProTracker, nor will it be in this package.
9xy Set sample offset This effect causes the note to start playing at an offset (of 256 times xy samples) into the sample, instead of just from the start.
Axy Volume slide Change the volume every but the first tick: increase with x, decrease with y.
Bxy Position jump Jump to position xy of the pattern sequence table.
Cxy Set volume Set the volume with xy.
Dxy Pattern break Break to row xy in the next pattern. Note: xy is (even though it is a hexadecimal) interpreted as a decimal.
E0x Turn filter on/off If x is even, the (emulated) hardware filter is turned on (for all tracks). It is turned off if x is odd.
E1x Porta up (fine) The period value is decreased with x, at the first tick.
E2x Porta down (fine) The period value is increased with x, at the first tick.
E3x Glissando Control This effect causes a change in the effect 3xy (porta to note). It toggles whether to do a smooth slide or whether to slide in jumps of semitones. When x is 0 it uses a smooth slide, non-zero values will result in jumps.
E4x Vibrato Waveform This effect sets the waveform for the vibrato command to follow. With x modulo 4 equals 0, a sine wave is used, with 1 ramp down, with 2 or 3 a square wave. Values greater than 4 causes the ossicating waveform not to retrigger it when a new note is played.
E5x Set finetune Set the finetune with x, where x is interpreted as a signed nybble.
E6x Pattern loop Set pattern loop start with E60, and loop x times when x is non-zero.
E7x Tremolo waveform Same as E4x, but this controls the wave form for the tremolo effect (7xy) rather than the vibrato effect.
E8x Not implemented According to official documentation this command is not implemented in ProTracker, but it is. Applies a filter on a looped sample, therewith destroying the original sample data. In many cases this effect is not used like this, rather programmers used this to trigger certain (visual) effects and synchronise those with the music being played.
E9x Retrigger note Retrigger the note every x-th tick.
EAx Volume slide up (fine) Increase the volume with x at the first tick.
EBx Volume slide down (fine) Decrease the volume with x at the first tick.
ECx Cut note Cut the volume of the note to zero after x ticks.
EDx Delay note The note is triggered with a delay of x ticks.
EEx Pattern delay The duration of the row in ticks is multiplied by (x + 1).
EFx Not implemented According to official documentation this command is not implemented in ProTracker, but it is. It flips sample data in a looped sample, therewith destroying the original sample data.
Fxy Set speed or tempo When xy is smaller then 32, it sets the speed in ticks per row. When xy is greater than 31, it will set the tempo, wich is inversely related to the duration of each tick. Speed and tempo can be defined in combination.

Extracting and updating effect commands

To get an effect command from a ProTracker module, you can simply call pt2_command() to a pt2cell or pt2celllist class object (see vignette("s3class") for a ProTrackR2 object tree). There, are several ways of extracting cells as documented in vignette("sel_assign"). In the example below there is one way shown of getting the effect commands of the first 8 rows of the second column in the third pattern.

mod <- pt2_read_mod(pt2_demo())
pt2_command(
  mod$patterns[[ 3 ]] [ 1:8, 2 ])
#> C40
#> C30
#> 000
#> 000
#> 000
#> 000
#> 000
#> 000

You can also assign new effect commands to your selection like this:

pt2_command(
  mod$patterns[[ 3 ]] [ 1:8, 2 ]) <- "C10"