The building blocks bidules are aimed at the more experienced
users. Their main feature is that they have inputs for their main parameters
instead of a GUI which means that the parameter values are applied at each
sample instead of at each block of samples. With these you can design
your own effects and synths.
Really basic audio buffer that let you decide which index position to record/play.
Take note that play has priority on record, meaning that if the buffer is
both playing and recording, the buffer will output the sample at the given
position inside the buffer before replacing it with the new one.
- Size in ms: the length of the audio buffer in memory
- Interpolation: method used to interpolate samples when the playback speed is different than 1.0
- Audio Input: input for the audio signal you might want to record
- Play Position Input: wanted index position to play at each sample
- Play Gate Input: once a 1 is received the playing will continue for as long that 1 is received in this input
- Record Gate Input: once a 1 is received the recording will continue for as long that 1 is received in this input
- Record Position Input: wanted index position to record at each sample
- Clear Contents Trigger input: send a trigger here to erase the contents of the buffer
- # of samples in buffer Output: the total amount of samples (ie sample rate multiplied by time) available in the buffer,
use this to know the upper bound to use (typically in an Accum) in the position inputs
An evolution of the Basic Audio Buffer to include a display (where you can set the in and out points also
throuh parameter linking) of the contents of the buffer. (Notice the extra + and - buttons (mouse wheel can also be used) in the toolbar to zoom in and out)
This is a simplified version where the position index is internally managed.
- Size in ms: the length of the audio buffer
- Interpolation: method used to interpolate samples when the playback speed is different than 1.0
- File/Save: set a filename to record the selected portion to a file and add it to the mediapool
- Audio Input: input for the audio signal you might want to record
- Play Gate Input: once a 1 is received the playing will continue for as long that 1 is received in this input
- Playback speed multiplier Input: playback speed
- Record Gate Input: once a 1 is received the recording will continue for as long that 1 is received in this input
- Clear Contents Trigger input: send a trigger here to erase the contents of the buffer
- # of samples in buffer Output: # of samples in buffer Output: the total amount of samples (ie sample rate multiplied by time) available in the buffer
An evolution of the Basic Audio Buffer to include a display (where you can set the in and out points also
throuh parameter linking) of the contents of the buffer. (Notice the extra + and - buttons (mouse wheel can also be used) in the toolbar to zoom in and out)
- Size in ms: the length of the audio buffer
- Interpolation: method used to interpolate samples when the playback speed is different than 1.0
- File/Save: set a filename to record the selected portion to a file and add it to the mediapool
- Audio Input: input for the audio signal you might want to record
- Play Gate Input: once a 1 is received the playing will continue for as long that 1 is received in this input
- Play Position Input: wanted index position to play at each sample
- Record Gate Input: once a 1 is received the recording will continue for as long that 1 is received in this input
- Record Position Input: wanted index position to record at each sample
- # of samples in buffer Output: use this to know the upper bound to use in the play position input
use this to know the upper bound to use (typically in an Accum) in the position inputs
- Loop in point output: The index in the buffer for the loop start point as driven by the UI or parameter linking
- Loop out point output: The index in the buffer for the loop end point as driven by the UI or parameter linking
Really basic file player that let you decide which position index to play.
- Audio File: select a file from the MediaPool
- Add Files: shortcut to add audio files to the MediaPool
- Interpolation: calculation method for interpolating samples when playing at speeds different than 1x
- Play Trigger Input: send a 1 to start the playback of the file
- Play Gate Input: once a trigger is received the playing will continue for as long that 1 is received in this input
- Play Position Input: wanted sample to play at each sample
- Amplitude Input: wanted amplitude to apply to the output
- # of samples in audio file Output: use this to know the upper bound to use in the play position input or to calculate the length of the file with the sample rate output
- Sample Rate of Audio File Output: sampling rate of the currently selected audio file
ADSR envelope
- Gate Input: gate input for the duration of the A, D, and S parts of the envelope
- Retrigger Input: retrigger the ADSR by sending a 1
The second output is an activity gate, it will output 1 for the entire
time that the envelope is active.
AHDSR envelope, the H stands for hold, it's the amount of time the Attack value is maintained before going to the decay state
- Gate Input: gate input for the duration of the A, H, D, and S parts of the envelope
- Retrigger Input: retrigger the AHDSR by sending a 1
The second output is an activity gate, it will output 1 for the entire
time that the envelope is active.
Basic ADSR envelope, same as the ADSR envelope except that the values used
are inputs instead of sliders.
- Attack Input: Attack time in ms
- Decay Input: Decay time in ms
- Sustain Input: Sustain level in %
- Release Input: Release time in ms
- Gate Input: gate input for the duration of the A, D, and S parts of the envelope
- Retrigger Input: retrigger the ADSR by sending a 1
The second output is an activity gate. It will output 1 for the entire
time that the envelope is active.
Basic AHDSR envelope, same as the AHDSR envelope except that the values used
are inputs instead of sliders.
- Attack Input: Attack time in ms
- Hold Input: Hold time in ms
- Decay Input: Decay time in ms
- Sustain Input: Sustain level in %
- Release Input: Release time in ms
- Gate Input: gate input for the duration of the A, H, D, and S parts of the envelope
- Retrigger Input: retrigger the AHDSR by sending a 1
The second output is an activity gate. It will output 1 for the entire
time that the envelope is active.
Basic Exponential Envelope
Basic exponential envelope.
Same as the Exponential Envelope except that the decay time
is an input instead of a parameter.
Basic envelope follower.
The second output is an activity gate, it will output 1 for the entire
time that the envelope is active.
Exponential envelope.
The second output is an activity gate. It will output 1 for the entire
time that the envelope is active.
Graphical (Trigger) Envelope
Graphical (Trigger) Envelope
Multipoint envelope automation whose transversal is activated (and reset) by a trigger signal.
The base unit is in seconds. You can move points and delete them using the delete key (once they are highlighted in blue).
you can select multiple points when holding the Ctrl(Windows)/Command(OS X) key.
Synched Graphical (Trigger) Envelope
Synched Graphical (Trigger) Envelope
Same thing as a Graphical (Trigger) Envelope, except that its time base is in quarter notes (PPQ)
and it will follow the tempo of a sync source. It will NOT play if not synced or if the sync source is stopped
Basic allpass filter.
- Audio Input: input for the audio signal
- Delay Time: delay time for the filter (in ms)
Slightly different version of the Allpass filter consisting of a delay line and low pass filter
- Audio Input: input for the audio signal
- Delay Length: delay time (in samples)
Collection of basic one pole, one zero and one pole/one zero 6db filters
that you can cascade to create others.
- Type: select the type of filter
Basic biquad filter.
- Audio Input: input for the audio signal
- Frequency Input: frequency to use for the filter for the current sample (in Hz)
- Q/Bandwidth: Q/Bandwidth for the current sample, depending on the selected filter type
Basic comb filter.
- Audio Input: input for the audio signal
- Delay Time: delay time for the filter in ms
Better version of the comb filter.
- Audio Input: input for the audio signal
- Delay Time: delay time for the filter in samples
- Filter Frequency: frequency value to use for the comb filter internal filter
Basic crossover filter.
- Audio Input: input for the audio signal
- Frequency Input: frequency to use for the filter for the current sample (in Hz)
Only does Hilbert 90 degree phase shift for now. And coeffs are only valid
in 44100 or 48000 sampling rates (for now).
Brute-force convolution through a loaded impulse or a user drawn waveform, length can be set
by user, fading out the impulse is optional but recommended if the impulse is longer than
the maximum length
- Audio Input: input for the audio signal
- Audio Output: convolution result
- Latency in samples: latency introduced by the convolution depending on the parameter values
Outputs a 1 at each sample a MIDI event occurs.
Creation of MIDI Aftertouch events. It stores the last value
for any given Aftertouch note number and will output an Aftertouch event only
if the value has changed. The amount of created events
is bound by the MIDI specifications which means about
a thousand events per second.
- Aftertouch Note Number Input: the note number of the Aftertouch event to create
- Aftertouch Normalized Value Input: the Aftertouch value remapped between 0 and 1
- Trigger Input: to force the creation of an Aftertouch event (otherwise only created when the number or value input has changed)
- Auto-detect value changes parameter: keep track of the incoming values and create new events when there is change if this is off, events are only created when
a trigger is received.
Extraction of MIDI Aftertouch events. When an Aftertouch event is received
the outputs are changed to reflect that value.
- Note Number Output: the note number of the Aftertouch event
- Normalized Value Output: the Aftertouch value remapped between 0 and 1
Change the MIDI channel of incoming MIDI events to the input value, specially useful when using
extractors/creators to manipulate MIDI events
- MIDI Channel Input: the channel to remap the event to
Creation of MIDI CC events. It stores the last value
for any given CC number and will output a CC event only
if the value has changed. The amount of created events
is bound by the MIDI specifications which means about
a thousand events per second.
- CC Number Input: the number of the CC to create
- CC Normalized Value Input: the CC value remapped between 0 and 1
- Trigger Input: to force the creation of a CC (otherwise CCs are created only when CC number or value has changed)
- 14bit CCs Mode: create 14bit CC instead of 7bit if the CC number is valid (0-31)
- Auto-detect value changes parameter: keep track of the incoming values and create new events when there is change if this is off, events are only created when
a trigger is received.
Possibility to create all 128 MIDI CCs in a single bidule, this will
keep track of the last value for all CCs and only output a new CC if the
incoming value has changed
- CC Normalized Value Input: the CC value remapped between 0 and 1
Extraction of MIDI CC events. When a CC event is received
the outputs are changed to reflect that value.
- CC Number Output: the number of the CC
- CC Normalized Value Output: the CC value remapped between 0 and 1
- 14bit CCs Mode: interpret CCs 0 to 31(32-63) as 14bit instead of pair of 7bit
Extraction of all 128 MIDI CCs in a single bidule
- CC Normalized Value Output: the CC value remapped between 0 and 1
Extraction of the MIDI Channel of any incoming MIDI event.
- Channel Number Output: the channel number for the event
Creation of MIDI Channel Pressure events. It stores the last value and will output
an event only if the value has changed. The amount of created events is bound by the MIDI
specifications which means about a thousand events per second.
- Channel Pressure Normalized Value Input: the Channel Pressure value remapped between 0 and 1
- Trigger Input: to force the creation of a Channel Pressure event (otherwise only created when the number or value input has changed)
- Auto-detect value changes parameter: keep track of the incoming values and create new events when there is change if this is off, events are only created when
a trigger is received.
Channel Pressure Extractor
Extraction of MIDI Channel Pressure events. When a Channel Pressure event is received
the output is changed to reflect that value.
- Normalized Value Output: the Channel Pressure value remapped between 0 and 1
Delays the MIDI event for a specified amount of time in samples, the delay time
is taken at the same sample index in the current buffer that the MIDI event.
- Delay time in samples: the amount of samples to delay the event
Use a gate signal at audio rate to control if a MIDI event
goes through or not, the gate value is taken at the same sample index in the current buffer that the MIDI event.
- Gate Signal: 1 to let event pass, 0 to block
Map: association between a number(key) and a MIDI event(value), the data will be kept until it is explicitely cleared or overwritten
- Read Index Input: send the key for the MIDI event you wish to read, will be read as an integer
- Read Trigger Input: send a 1 to read the MIDI event at the read index
- Write Index Input: send the key for the MIDI event you wish to write, will be read as an integer
- Write Trigger Input: send a 1 to write the MIDI event to the write index
- Clear Index Input: send the key for the value you wish to remove from the map, will be read as an integer
- Clear Trigger Input: send a 1 to clear the value at the clear index
- Clear All Trigger Input: empty the contents
- Write Event Input: send the MIDI event to be saved at the write index
- Number of Elements Output: the current number of key-value pairs in the map
- Event Output: the MIDI event when a read trigger occurs
Create MIDI messages directly (Note: there is no validation on the resulting MIDI message) by specifying the 3 data bytes.
- data0, data1, data2 Inputs: value for the 3 data bytes of a MIDI message
- Trigger Input: to force the creation of a message event (otherwise only created when an input has changed)
- Auto-detect value changes parameter: keep track of the incoming values and create new events when there is change if this is off, events are only created when
a trigger is received.
Extracts MIDI messages directly (Note: there is no validation on the incoming MIDI message) to the 3 data bytes.
- data0, data1, data2 outputs: value for the 3 data bytes of a MIDI message
Will act as a passthrough and keep track of opened notes, when it receives
a trigger (1.0) signal on its audio input, it will send Note Off events (at
the same sample index the trigger is received) for all currently opened notes.
The opposite of the MIDI Note Extractor: use values to generate MIDI notes.
- Frequency Input: frequency value for the outgoing MIDI note (in Hz)
- Amplitude Input: velocity value remapped between 0 and 1
- Gate Input: input for the gate signal, set to 1 on MIDI Note On until a MIDI Note Off is received
- Trigger input: input for triggers, set to 1 for the sample on which the MIDI note should be created
- Add Microtonal info (param): if this is selected, the outgoing MIDI notes will carry a detune factor if the frequency input is not an exact MIDI note
Look at the Arpeggiator group's internals for an example of how to use the MIDI Note Creator.
MIDI note creator for creating multiple notes, this version doesn't keep
memory of what note is on or off
- Frequency Input: frequency value for the outgoing MIDI note (in Hz)
- Amplitude Input: velocity value remapped between 0 and 1
- Note On Trigger Input: send a 1 when you want to create a Note On event
- Note Off Trigger Input: send a 1 when you want to create a Note Off event
- Add Microtonal info (param): if this is selected, the outgoing MIDI notes will carry a detune factor if the frequency input is not an exact MIDI note
Useful information extracted from MIDI Note On/Off events.
- Frequency Output: frequency value for the incoming MIDI note with pitch bend applied (in Hz)
- Amplitude Output: velocity value remapped between 0 and 1 (NOTE ON only!)
- Gate Output: output for gate signal, set to 1 on MIDI Note On until a MIDI Note Off is received
- Trigger Output: output for triggers, set to 1 for the sample on which the MIDI note is received
- Stealing Mode: select "Use Lowest" to have portamento
- Glide Time: used when in portamento mode
- Wheel Range: range of the pitch bend in cents
- Always Retrig: select this to send a trigger output even if the note is currently in legato (portamento mode)
Note that once a note is rececived, the frequency and amplitude outputs will continue to output the previous note's information, even if note becomes OFF (gate=0). This is useful to allow for proper envelope release. Please look at the "PhatSynth" group's
internals for an example.
MIDI note extractor similar to MIDI Note Creator 2 contrary to the MIDI Note Extractor
this version doesn't keep memory of what note is on or off
- Frequency Output: frequency value for the incoming MIDI note (in Hz)
- Amplitude Output: velocity value remapped between 0 and 1
- Note On Trigger Output: sends a 1 on a Note On event
- Note Off Trigger Output: sends a 1 on a Note Off event
Creation of MIDI Pitchbend events from values, events will be created automatically when the input value changes
- Normalized Value Input: the value for the Pitchbend remapped between -1 and 1 where 0 is no pitch change
- Trigger Input: send a 1 to force the creation of a Pitchbend event even if the number hasn't changed
- Auto-detect value changes parameter: keep track of the incoming values and create new events when there is change if this is off, events are only created when
a trigger is received.
Extraction of MIDI Pitchbend events. When a Pitchbend event is
received the output is changed to reflect that value.
- Normalized Value Output: the value for the Pitchbend remapped between -1 and 1 where 0 is no pitch change
Creation of MIDI Program Change events from values, events will be created automatically when the input value changes
- Program Change Number Input: the program number for the event to create
- Trigger Input: send a 1 to force the creation of a program change event even if the number hasn't changed
- Auto-detect value changes parameter: keep track of the incoming values and create new events when there is change if this is off, events are only created when
a trigger is received.
Extraction of MIDI Program Change events. When a Program Change event is
received the output is changed to reflect that value.
- Program Number Output: the program number for the event
Stack for MIDI events that can be set either as FIFO (first in first out, i.e. events
comes out in the same order they came in) or LIFO (last in first out i.e. events comes
out in the opposite order they came in).
- Pop Trigger Input: send a 1 to remove the next event from the stack
- Push Trigger Input: send a 1 put the MIDI event at the current sample in the stack
- Event Input: send your MIDI stream here
- Empty Stack Trigger Output: sends a 1 when the last element of the stack has been popped
- Event Output: outputs the popped MIDI event
Outputs the time in samples between the last two MIDI events.
Outputs the current number of voices for the MIDI stream connected at its input.
Accumulate at each sample by a specified amount and output the value at each sample with
defined minimum and maximum values.
- Accumulation type: select the wanted operation to use
- Loop values between low/high: if this is selected, the accum will wrap around when hitting the lower/upper bound
- Value to Accum Input: at each sample, use this value and the selected operation on the current value to get the new current value
- Start Value Input: the start value
- Reset Trigger Input: when a 1 is received, resets the accumulated value to the minimum
- Inclusive Lower Bound Input: lower bound of the accum
- Exclusive Higher Bound Input: upper bound for the accum
- Wrap Around Output: outputs a 1 when wrapping from max to min value
Simple logic operator.
- Left-Side Argument Input: input for the left-side argument of the logic operator
- Right-Side Argument Input: input for the right-side argument of the logic operator
Math binary operators.
- +
- -
- *
- /
- %
- **
- MIN
- MAX
- LOUDEST
- QUIETEST
- atan2
Monitors the incoming signal and outputs 0 when the current sample value is the same as
the previous one, 1 when it's greater, and -1 when it's lower.
Clips the incoming signal between the specified minimum and maximum values. Don't forget
to hit ENTER to validate a value you just typed.
Useful set of available constants; you can also specified your own.
Simple counter with specified minimum and maximum values.
Don't forget to hit ENTER to validate a value you just typed.
- Number of samples to increment at Input: used to specify the counting interval.
(I.e. increment at each 10000 samples)
- Reset Trigger Input: send a 1 to reset the counter
Mathematical expression with up to 3 variables (fed into the three inputs) that is evaluated at
each sample. Don't forget to hit ENTER to validate the function you just typed.
The following functions and constants are available:
- +,-,*,/
- abs(x)
- floor(x)
- ceil(x)
- exp(x)
- ln(x)
- sin(x)
- sinh(x)
- cos(x)
- cosh(x)
- tan(x)
- tanh(x)
- asin(x)
- acos(x)
- atan(x)
- sqrt(x)
- atan2(x,y)
- mod(x,y)
- min(x,y)
- max(x,y)
- pi()
Same as the Function bidule except that you have access to
the 4 previous values of each variable as well as the 4 previous
results using the following functions with 1,2,3 or 4 as the
parameter.
- prevX(n)
- prevY(n)
- prevZ(n)
- prevR(n)
Simple logic gate.
- Left-Side Argument Input: input for the left-side argument of the logic operator
- Right-Side Argument Input: input for the right-side argument of the logic operator
- Value for True Input: input to be redirected to the output when the operator result is true
- Value for False Input: input to be redirected to the output when the operator result is false
A 512 point lookup table with linear interpolation.
- Index Input: input for 0-based index of the point you want
- Value Output: value (interpolated if needed) for the wanted point
Math unary operators.
- INVERSION
- RECIPROCAL
- ABS
- FLOOR
- CEIL
- SQUARE
- CUBE
- SQRT
- EXP
- LOG
- LOG10
- SIN
- COS
- TAN
- ASIN
- ACOS
- ATAN
- SINH
- COSH
- TANH
- LOGICAL NOT
- ROUND
Useful sets of common unit conversions.
A list of values separated by a semi colon (';'). A value will be output until
the next trigger is received - by sending a 1 in the trigger input.
The second input is used to reset the list to its first member (without
requiring to wait until the list loops back to start).
A variation on the Value List, it adds some useful outputs
- Current Index Output Output: The index of the current value
- Total Elements Output: The current number of values in the list
- Wraparound Trigger Output: sends a single trigger when the current index goes back to 0
A list of values separated by a semi colon (';').
- Index Input: Index of the value to output
- Value Output: The value
- Number of Values Output: The current number of values in the list
User-defined variable range with slider and input box. Don't forget to hit ENTER to validate
a value you just typed.
- Min and Max: define the range of the slider
Same as the Variable except that the value will always be an integer.
Let you send an OSC message at a specified OSC address, the number of arguments of the sent message is the number
of connected inputs.
- Parameter 1 to 8 Inputs: parameters for the OSC message
- Trigger to send message Input: send a 1 to use the values at the parameter inputs to send an OSC message
- Force int parameters (param): message will be send with integers instead of floats parameters
More complex and flexible version of OSC Creator, the number of arguments of the sent message is the number
of connected inputs and any parameter defined as String.
- Parameter 1 to 8 Inputs: parameters for the OSC message
- Trigger to send message Input: send a 1 to use the values at the parameter inputs to send an OSC message
- OSC Parameter Type :
- Float from input: take the incoming signal and use it for a float parameter to the OSC message.
- Int from input: take the incoming signal and use it for a integer parameter to the OSC message.
- String: take the value field and use it for a string parameter to the OSC message.
- Format string with float input: C format string to generate the parameter value using the value field and the incoming signal as a float: param_%f
- Format string with int input: C format string to generate the parameter value using the value field and the incoming signal as a int : voice_%n
- OSC Parameter Value: only used for String, Format string with float input, Format string with int input.
Let you specify an OSC address to receive OSC message
- Parameter 1 to 8 Outputs: parameters for the OSC message
- Trigger on message received Ouput: sends a 1 when an OSC message is received at the specified address
Send and receive MIDI using OSC, the OSC address it sends to and receives from is the path and name of the bidule
appended with MIDI ( e.g. /OSC_MIDI_0/MIDI if it's in the root of a layout, /GroupName/OSC_MIDI_0/MIDI if it's inside a group
named GroupName and that group is in the root of the layout). The expected message format is 3 integer parameters representing
the 3 MIDI bytes, an optional fourth float parameter can be use to apply a detune in cents.