Samplers
This page presents many functions related to the use of samples inside TidalCycles.
For specific information about functions used to slice and loop samples see Sampling.
Each function will be presented following the same model:
- Type signature: how the function is declared on the Haskell side.
- Description: verbal description of the function.
- Examples: a small list of examples that you can copy/paste in your editor.
Amplitude manipulation
These functions are used to control the amplitude (volume) of the sounds.
amp
Type: amp :: Pattern Double -> ControlPattern
amp
controls the amplitude of the sound using a linear function. Its default value is 0.4
. For the power function equivalent, see gain
.
d1 $ s "arpy" # amp 0.6
This will play the first arpy
sample at a volume slightly louder than the default.
d1 $ s "arpy" # amp "<0.4 0.8 0.2>"
In the above example, the volume changes at each cycle.
gain
Type: gain :: Pattern Double -> ControlPattern
gain
controls the amplitude of the sound using a power function. Its default value is 1
. Smaller values make the sound quieter, and greater values make the sound louder.
As gain
uses a power function, the volume change around 1
is subtle, but it gets more noticable as it increases or decreases. Typical values for gain
are between 0
and 1.5
. For the linear equivalent, see amp
.
d1 $ s "arpy" # gain 0.8
This plays the first arpy
sample at a quieter level than the default.
d1 $ s "ab*16" # gain (range 0.8 1.3 $ sine)
This plays a hihat sound, 16
times per cycle, with a gain
moving from 0.8
to 1.3
following a sine wave.
Speed-related effects
This section presents effects that change both the speed and the pitch of the samples.
accelerate
Type: accelerate :: Pattern Double -> ControlPattern
A pattern of numbers that speed up (or slow down) samples while they play.
d1 $ s "arpy" # accelerate 2
In this example, the sound starts at the original pitch, and gets higher as it plays. You can use a negative number to make the sound get lower.
d1 $ arp "up" $ note "c'maj'4" # s "arpy" # accelerateTake "susan" [0.2,1,-1]
Using state values, in this example we apply a different acceleration to each played note.
speed
Type: speed :: Pattern Double -> ControlPattern
A pattern of numbers which changes the speed of sample playback. As a result, the sample duration and pitch will be modified. Negative values will play the sample backwards.
d1 $ slow 5 $ s "sax:5" # legato 1 # speed 0.5
This will play the sax:5
sample at half its rate. As a result, the sample will last twice the normal time, and will be pitched a whole octave lower. This is equivalent to d1 $ slow 5 $ s "sax:5" # legato 1 |- note 12
.
d1 $ fast 2 $ s "breaks125:1" # cps (125/60/4) # speed (-2)
In the above example, the break (which lasts for exactly one bar at 125 BPM), will be played backwards, and at double speed (so, we use fast 2
to fill the whole cycle).
unit
Type: unit :: Pattern String -> ControlPattern
unit
is used in conjunction with speed
. It accepts values of "r" (rate), "c" (cycles), or "s" (seconds).
unit "r"
is the default. See the above speed
section.
Using unit "c"
means speed
will be interpreted in cycles. For example, speed 2
means samples will be stretched to fill half a cycle:
d1 $ stack [
s "sax:5" # legato 1 # speed 2 # unit "c",
s "bd*2"
]
Time stretching
According to Wikipedia, time stretching is the process of changing the speed or duration of an audio signal without affecting its pitch.
This section presents the functions available in TidalCycles that let us time-stretch our samples at real time.
timescale
Type: timescale :: Pattern Double -> ControlPattern
timescale
is the main function used to activate time-stretching, and usually the only one you need. It receives a single parameter which is the stretching rate to apply.
You can use any positive number as the ratio, but the particular method used is designed for ratios greater than 1, and work reasonably well for values between 0.1 and 3.
d1 $ slow 2 $ s "breaks152" # legato 1 # timescale (152/130) # cps (130/60/4)
In the example above, we set tempo at 130 beats per minute. But we want to play one of the breaks152
samples, which are, as indicated, at 152 BPM. So, the ratio we want is 152 over 130. This will slow down the sample to fit in our 130 BPM tempo.
timescalewin
Type: timescalewin :: Pattern Double -> ControlPattern
The algorithm used to time-stretch a sample divides our sample in many little parts, modifies them, and puts them all together again. It uses one particular parameter, called windowSize
, which is the length of each sample part.
The windowSize
value is automatically calculated, but we can change it using timescalewin
. The windowSize
value is multiplied by the number we provide to timescalewin
.
timescalewin
can be used to improve the quality of time-stretching for some samples, or simply as an effect.
Let's compare the next two code examples:
d1 $ slow 2 $ s "breaks152" # legato 1 # timescale (152/130) # timescalewin 0.01 # cps (130/60/4)
d1 $ slow 2 $ s "breaks152" # legato 1 # timescale (152/130) # timescalewin 10 # cps (130/60/4)
In the first one, passing 0.01
makes the window size a lot smaller, and the extreme chopping of the sample causes a rougher sound.
In the second one, passing 10
makes the chunks a lot bigger. The method used overlaps the treated chunks when recomposing the sample, and, with the bigger window size, this overlap is noticeable and causes a kind of delay effect.