Skip to content

The Prototype

passivist edited this page Oct 15, 2016 · 13 revisions

The Prototype

The SuperCollider patch this plugin is based on grew out of a longer occupation with granular synthesis and more specifically the lecture of Curtis Roads book "Microsound". It was at first developed without a GUI completely relying on SuperColliders pattern system. In preparation for a workshop on granular synthesis with SuperCollider I gave in 2015 it was developed and given more or less it's current form.

I think the prototype can serve as a nice reference when trying to understand my thought process and my design decisions that went into the final plugin. I recommend browsing playing around with the prototype and the source code a bit to get a feel for it before you proceed to the concept.

A semi-short overview

The prototype is split into four files: INIT_GRNLR.scd, GRNLR_GUI.scd, GRNLR_ENGINE.scd, grnlr_synth.scd. The files are separated by task to keep the code more readable.

INIT_GRNLR.scd contains general setup and initialization of variables and loads and executes the contents of GRNLR_GUI.scd and grnlr_synth.scd which holds the SynthDef a SuperCollider Class that is responsible for defining the function that produces the sound in the end (that explanation is of course criminally oversimplified).

GRNLR_GUI handles as the name implies all GUI related operations. That specifically means setting up the window and handling all the interaction the user has with GUI elements such as sliders and buttons. All the variables are stored in a dictionary we initialize at the top of the file. This dictionary is (in classic SuperCollider style) "sort of global". More precisely it's an environment variable that is in the namespace of the current environment.

GRNLR_ENGINE.scd contains the main routine (a Tdef or Task definition which is basically a named routine). This routine is responsible for getting the values of all the GUI elements and other variables and triggering grains with those values. Later in the file the handling of MIDI data is defined.

Clone this wiki locally