06-table-stutter.py - Variable length table reading.¶
This little program use a function and a time-variable function caller to stutter a sound loaded in a table. The starting point of the table playback is set initially to near the end of the table, and move toward the beginning each time a new playback is called.
For the playback, we use a Pointer object, which is a table reader with control on the pointer position (normalized between 0 and 1).
from pyo import *
import random
s = Server().boot()
STUTTER = 0.025  # Delta time added each time the playback restart.
FADETIME = 0.01  # Fadein-fadeout time to avoid clicks.
# Load a sound in the table and get its duration.
table = SndTable(SNDS_PATH + "/transparent.aif")
tabdur = table.getDur()
# Intialize the line used to read the table.
line = Linseg([(0, 0), (1, 1)])
# Amplitude envelope, to avoid clicks.
amp = Fader(FADETIME, FADETIME, dur=STUTTER, mul=0.5)
amp.setExp(2)
# Read the sound and mix it to stereo.
read = Pointer(table=table, index=line, mul=amp).mix(2).out()
# Global variables (start position and playback duration).
start = tabdur - STUTTER
dur = STUTTER
def go():
    "Read a segment of a sound table and set the duration before the next iteration."
    global start, dur
    # Create the pointer segment (from normalized start position to the end of the table)
    line.list = [(0, start / tabdur), (dur, 1)]
    # Assign duration to the envelope and the function caller (Pattern).
    amp.dur = pat.time = dur
    # Decrement start position and increment duration by STUTTER seconds.
    start -= STUTTER
    dur += STUTTER
    # Reset start and dur variables when reaching the beginning of the sound.
    if start < 0:
        start = tabdur - STUTTER
        dur = STUTTER
    # Activate the pointer's index line and the amplitude envelope.
    line.play()
    amp.play()
# Call go() each time the playback reaches the end of the file
pat = Pattern(function=go, time=STUTTER).play()
s.gui(locals())