Venom modules version 2.13.1 for VCV Rack 2 are copyright 2023, 2024, 2025 Dave Benham and licensed under GNU General Public License version 3.
Color Coded Ports
Themes
Custom Names
Parameter Locks and Custom Defaults
Venom Expander Modules
Anti-aliasing via oversampling
Acknowledgments
AD/ASR ENVELOPE GENERATOR |
AUXILLIARY CLONE EXPANDER |
BAY MODULES | BENJOLIN OSCILLATOR |
BENJOLIN GATES EXPANDER |
BENJOLIN VOLTS EXPANDER |
---|---|---|---|---|---|
![]() |
![]() |
![]() ![]() ![]() |
![]() |
![]() |
![]() |
BERNOULLI SWITCH |
BERNOULLI SWITCH EXPANDER |
BLOCKER | BYPASS MODULE |
CLONE MERGE |
CROSS FADE 3D | HARMONIC QUANTIZER |
KNOB 5 |
---|---|---|---|---|---|---|---|
![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
LINEAR BEATS |
LINEAR BEATS EXPANDER |
LOGIC | MIX 4 | MIX 4 STEREO |
MIX EXPANDERS |
---|---|---|---|---|---|
![]() |
![]() |
![]() |
![]() |
![]() |
![]() ![]() ![]() ![]() ![]() ![]() ![]() |
MOUSE PAD |
MULTI MERGE |
MULTI SPLIT |
NON-OCTAVE REPEATING SCALE INTERVALLIC QUANTIZER |
NORSIQ CHORD TO SCALE |
PAN 3D |
---|---|---|---|---|---|
![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
POLY CLONE |
POLY FADE | POLY OFFSET |
POLY SAMPLE & HOLD ANALOG SHIFT REGISTER |
POLY SCALE |
POLY UNISON |
PUSH 5 | QUAD VC POLARIZER |
RECURSE |
---|---|---|---|---|---|---|---|---|
![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
RECURSE STEREO |
REFORMATION | RHYTHM EXPLORER | SHAPED VCA |
SLEW |
---|---|---|---|---|
![]() |
![]() |
SPHERE TO XYZ |
THRU | VCA MIX 4 | VCA MIX 4 STEREO | VCO LAB | VCO UNIT |
---|---|---|---|---|---|
![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
VENOM BLANK |
WAVE FOLDER |
WAVE MANGLER |
WAVE MULTIPLIER |
WIDGET MENU EXTENDER |
---|---|---|---|---|
![]() |
![]() |
![]() |
![]() |
WINCOMP | WINCOMP 2 + LOGIC | XM-OP |
---|---|---|
![]() |
![]() |
All polyphonic ports use brass cores, while monophonic ports use steel cores.
Input ports are on the base faceplate color, and output ports are on a contrasting background color.
The context menu of every module includes options to set the default theme and default dark theme for the Venom plugin, as well as a theme override for each module instance.
There are 4 themes to choose from.
Ivory | Coal | Earth | Danger |
---|---|---|---|
![]() |
![]() |
![]() |
![]() |
If a module instance is set to use a specific theme, then that theme will be used regardless whether VCV Rack is set to use dark panels or not. If a module is set to use the default theme, then the VCV Rack "Use dark panels if available" setting controls which default is used. If not enabled, then the default theme is used. If enabled then the default dark theme is used.
If you want the default theme to disregard the VCV Rack dark panel setting, then simply set both defaults to the same theme.
The factory default theme is ivory, and the factory default dark theme is coal.
Nearly every port (input or output), and every parameter (module knob, switch, or button etc.) within the Venom plugin has its own context menu option to set a custom name. Custom names only appear in context menus and hover text - they do not change the faceplate graphics.
If a parameter or port is given a custom name, then an additional option is added to restore the factory default name.
Custom names are saved with the patch and with presets, and restored upon patch or preset load. Custom names are also preserved when duplicating a module.
Nearly every parameter (module knob, switch, or button etc.) within the Venom plugin has its own parameter context menu options to lock the paramenter as well as set a custom default value. In addition, most modules have module context menu options to lock and unlock all parameters within that instance of the module.
Parameter lock and custom default settings are saved with the patch and with presets, and restored upon patch or preset load. Parameter lock and custom default settings are also preserved when duplicating a module.
The parameter tooltip includes the word "locked" below the parameter name when hovering over a locked parameter.
The parameter value cannot be changed by any means while the parameter is locked. All of the normal means of changing a parameter value are blocked:
- The parameter cannot be dragged or pushed
- Context menu value keyins are ignored
- Double click and context menu initialization are ignored
- Randomization requests are ignored
A custom default value overrides the factory default whenever a parameter is initialized. An additional parameter menu option is added to restore the factory default whenever a custom default is in effect.
A number of Venom modules do not do anything on their own, but rather augment the functionality of a compatible base module when placed beside it. Each Venom base module that supports expanders has module context menu options to add expanders without having to open the module browser.
VCV Rack supports two different mechanisms for implementinig expander modules:
- Both the parent (base) module and the expander perform work, and they communicate with each other via messages that introduce sample delays, much as cables do in VCV Rack.
- The base module does all the work, accessing the expander inputs, outputs, and controls directly. This does not introduce any sample delays.
All Venom expanders are implemented using the second method where the base module directly accesses the expander, so Venom expanders do not introduce sample delays.
All digital synthesis techniques must deal with anti-aliasing to get the best possible audio output. Frequencies above 50% of the sample rate (the Nyquist frequency) cannot be represented, and instead are reflected back below the Nyquist frequency. Harmonically rich wave forms like a saw wave can have harmonics above the Nyquist frequency that create inharmonic audible tones when reflected, called aliasing. These reflections are typically not wanted, so most digital systems use one or more techniques to greatly reduce the amplitude of aliased harmonics so as to make them inaudible.
Venom uses oversampling as the primary anti-alias technique. Incoming signals are upsampled by factors of 2 with interpolation to get an effective sample rate with a much higher Nyquist frequency. All the digital computations are done at this higher frequency. The end result is filtered by a low pass filter with a cutoff below the true sample rate Nyquist frequency. This process removes the high frequency content before it can be aliased, and then it is downsampled to return to the actual sample rate. Note that any pre-existing aliasing at the inputs cannot be removed - high frequency content must be removed before it is ever aliased.
The higher the degree of oversampling, the better the result, but at the cost of higer CPU usage. Another factor is the slope of the low pass filters that are used for both the upsampling interpolation and the bandlimited downsampling. The higer the filter order, the steeper the slope, which allows for preservation of more high frequency content below the Nyquist frequency. But the higher filter orders also require more CPU. So it is a balancing act to select the minimum oversampling rate and filter order that gives good results.
Most Venom modules that use oversampling have parameters on the faceplate to chose the oversample rate. A few modules have context menu options instead. For most applications, an oversample rate of 4x or 8x gives good results, without using excessive CPU. But don't be afraid to try out more or less. In some cases you may be able to turn off oversampling entirely, and still get good results, thus saving considerable CPU.
All of the Venom modules with oversampling also have a context menu option to specify the quality of the filter used. There are three options available:
- 10th order with a cutoff at 80% of the Nyquist frequency. This is the default value used by all Venom modules.
- 8th order with a cutoff at 80% of the Nyquist frequency.
- 6th order with a cutoff at 50% of the Nyquist frequency.
Again, feel free to experiment to find what works best for you.
Special thanks to Andrew Hanson of PathSet modules for setting up my GitHub repository, providing advice and ideas for the Rhythm Explorer and plugins in general, and for writing the initial prototype code for the Rhythm Explorer.
Also a hearty thanks to Squinky Labs for their VCV Rack Demo project, which showed me how to implement oversampling, and also got my foot in the door to understanding how to use SIMD with plugin development.
Thanks to Jacky Ligon and Andreya Ek Frisk over on the Surge Discord server for advice on the NonOctave Repeating Scale Intervallic Quantizer, as well as help with compiling a representative set of scale presets.
Super thanks to Benjamin Dill for his open source Stoermelder PackOne plugin. I could never have developed the Widget Menu Extender module or the Bypass module without his tips and source code to study.
Thanks to Paul Dempsey for his MenuTextField struct from the pachde1 plugin that allows text entry in a menu. In turn that was developed using code/ideas from the SubmarineFree plugin by David O'Rourke.
Finally thanks to Ewan Hemingway. Through discussions and studying the Befaco Even VCO source code I was able to improve the sound quality of VCO Lab and VCO Unit by adding DPW alias suppression to supplement oversampling.
Hybrid polyphonic AD (Attack|Decay) and ASR (Attack|Sustain|Release) envelope generator with looping capabilities and precise V/Oct CV control over stage lengths.
- Separate trigger and gate inputs allow one envelope generator to support both AD and ASR behaviors simultaneously
- Wide stage length range: 0.24 msec to 3 min
- Stage lengths are precise with accuracy dictated by VCV sample rate
- V/Oct CV control over stage lengths with attenuverters
- Independent stage shape controls for Rise and Fall: concave up to linear to concave down
- Changing a stage shape does not alter the overall time
- Multiple modes with different retrigger options: retrigger from 0 or current level
- Configurable Rise, Fall, and Sustain stage outputs indicate different events within the envelope
- Feedback from stage gates can block retrigger behavior and/or force ASR attack to rise to full value
- Loop options turn the envelope into a V/Oct LFO with CV control to start and stop the oscillation
- All inputs and outputs are polyphonic with support for audio rates
- The Attack (Rise) stage always rises to a full 10V, then immediately progresses to the Decay stage
- The Decay (Fall) stage falls back to 0V
There are also options as to whether a new AD envelope can be retriggered during the Rise and/or Fall stages.
- The Attack (Rise) stage rises toward 10V as long as the triggering gate remains high
- If gate goes low, then immediately jumps to the Release stage at current voltage
- If 10V is reached then progresses to Sustain stage
- The Sustain stage maintains 10V as long as the triggering gate remains high
- Progresses to the Release stage when gate goes low
- The Release (Fall) stage falls back to 0V
There are also options as to whether a new ASR envelope can be retriggered during the Rise and/or Fall stages.
Rise and Fall stages each have a large knob to set the base time of the stage, as well as a CV input and attenuator to dynamically modulate the time.
The total effective time for a Rise from 0 to 10 or Fall from 10 to 0 can be as short as 0.24 msec or as long as 3 minutes.
The small top left SPD (Speed) button sets the range of the time knobs:
- Slow (red): 0.044 to 181 seconds
- Medium (yellow, default): 0.0028 to 11.3 seconds
- Fast (green): 0.00024 to 1.0 seconds
The knob speed can be modulated by the associated CV input with attenuator. Each positive volt of CV doubles the length of the stage. Each negative volt cuts the length in half.
The CV can modulate the effective length beyond the limits of the current time knob configuration. However, the effective length is always clamped to between ~0.24 msec and ~3 min.
Note that floating point computations have limited precision that could cause an envelope to stall. If using the Slow configuration and the VCV sample rate is greater than 96 kHz, then the processing is automatically under-sampled to guarantee that the envelope never stalls. But if using the Medium or Fast speeds then it is possible for CV modulated slow envelopes to stall if the VCV sample rate is above 96 kHz. The envelope will never stall if stage length CV is not used.
The Rise and Fall stages each have a dedicated small knob to adjust the shape or curve of the stage.
- Counter-clockwise creates a concave up J curve
- Noon creates a linear rise or fall
- Clockwise creates a convex up J curve
Changing the shape does not change the overall time for a rise from 0 to 10V, or fall from 10 to 0V.
Envelopes are always triggered on the leading edge of a trigger or gate. TRIG triggers create AD envelopes, and GATE triggers create ASR envelopes.
TRIG and GATE each have a manual push button as well as a CV input. The state of manual push buttons and CV inputs are maintained independently.
By default, the manual TRIG and manual GATE buttons maintain a high state for as long as the button is pressed.
If the small top right TOG (Toggle) button is enabled (yellow), then the GATE button becomes a toggle switch. The first press of the GATE button switches the gate high, and the next press switches the gate low.
Triggers for TRIG and GATE CV are based on Schmitt triggers that go high above 2V and go low below 0.2V. Voltages between 0.2V and 2V maintain the current state.
The type of envelope generated (AD or ASR) depends on which trigger is received first, TRIG or GATE. TRIG (AD) triggers take precedence over GATE (ASR) triggers in the event of a tie.
All triggers are typically ignored if any of the other triggers or gates are already in a high state.
The small top middle MODE button can alter the behavior of TRIG and GATE, and controls when and how envelopes are retriggered. It can also cause envelopes to loop, effectively turning the module into an LFO.
There are four modes to choose from:
- Mode 1 (light blue, default) AD and ASR envelopes that can retrigger from the current value while falling
- Mode 2 (dark blue) AD and ASR envelopes that can retrigger from 0 while rising or falling
- Mode 3 (yellow) Looping envelopes that are started and stopped via TRIG, and a high GATE causes the oscillator to sustain 10V
- Mode 4 (green) TRIG initiated AD envelope if GATE is low, or looping AD envelope that is reset by TRIG if GATE is high
AD/ASR Rise stages that start above 0V due to a retrigger are shortened proportionally to where they start. Likewise, ASR Fall stages that start below 10V are also shortened proportionally.
Looping envelopes can behave like a V/Oct LFO if the V/Oct control voltage is patched to both the Rise and Fall CV inputs, and both attenuverters are set fully counter-clockwise to -100%. The looping frequency can go into audio rates as high as ~2 kHz, or slow LFO rates as low as ~0.0028 Hz (~6 minutes per cycle).
- AD Envelope
- Leading edge of a TRIG initiates an AD envelope.
- The envelope first rises to 10V, then falls back to 0V
- The AD envelope can actually sustain 10V if a high GATE is received after the AD has been triggered.
- A new envelope may be retriggered from the current voltage during the Fall stage
- ASR Envelope
- Leading edge of a GATE initiates an ASR envelope
- The envelope rises toward 10V for as long as the gate remains high
- If 10V is reached, then progresses to the Sustain stage
- If the gate goes low before 10V, then immediately jumps to the Fall stage
- The Sustain stage remains at 10V for as long as the gate remains high
- Progresses to the Fall stage when the gate goes low
- The Fall stage falls back to 0V
- A new envelope may be retriggered from the current voltage during the Fall stage
- AD Envelope
- Leading edge of a TRIG initiates an AD envelope.
- The envelope first rises to 10V
- A new envelope can be retriggered from 0 during the Rise stage
- The AD envelope can actually sustain 10V if a high GATE is received after the AD has been triggered.
- The Fall stage falls back to 0V
- A new envelope may be retriggered from 0V during the Fall stage
- ASR Envelope
- Leading edge of a GATE initiates an ASR envelope
- The envelope rises toward 10V for as long as the gate remains high
- If 10V is reached, then progresses to the Sustain stage
- If the gate goes low before 10V, then immediately jumps to the Fall stage
- The Sustain stage remains at 10V for as long as the gate remains high
- Progresses to the Fall stage when the gate goes low
- The Fall stage falls back to 0V
- A new envelope may be retriggered from 0V during the Fall stage
A short trigger at either TRIG or GATE starts the looping envelope to oscillate. Both manual buttons and CV inputs work equally well.
If the TRIG trigger lasts longer than the combined Rise and Fall time, then only a single envelope is produced and the oscillator stops.
If the GATE trigger lasts longer than the Rise time, then the oscillator rises and stalls at 10V until the gate goes low, at which point oscillation begins.
A running oscillator can be temporarily stopped at 10V by a high GATE. Oscillation will resume when the GATE goes low.
A running oscillator can be fully stopped by a high TRIG gate that remains high when the oscillator falls to 0V. Once stopped, oscillations will not resume until a new trigger is received.
Triggers are never blocked by a high gate at TRIG or GATE
If the GATE is low, then TRIG initiates a single shot AD envelope. The AD envelope can be retriggered from 0 during both the Rise and Fall stages.
If the GATE goes high, then the Rise stage immediately starts from 0, and the envelope oscillates for as long as the GATE remains high. The oscillator may be reset (hard synced) by a TRIG trigger at any time. Oscillations stop when the GATE goes low.
Each of the stage output ports has a small button next to the label to configure what exactly is produced at that output.
- Gate (dark blue, default) Produces a high gate (10V) whenever the envelope is rising toward 10V, else low (0V) otherwise.
- Start trigger (green) Produces a 1ms trigger upon entry to the Rise stage. The trigger may be shortened upon exit from the Rise stage.
- End trigger (red) Produces a 1ms trigger upon exit from the Rise stage. The trigger may be shortened upon rentry to the Rise stage.
Note that a Rise trigger is not fired if the envelope is retriggered during the Rise stage.
- Gate (dark blue, default) Produces a high gate (10V) whenever the envelope is sustaining 10V, else low (0V) otherwise.
- Start trigger (green) Produces a 1ms trigger upon entry to the Sustain stage. The trigger may be shortened upon exit from the Sustain stage.
- End trigger (red) Produces a 1ms trigger upon exit from the Sustain stage. The trigger may be shortened upon rentry to the Sustain stage.
- Gate (dark blue, default) Produces a high gate (10V) whenever the envelope is falling toward 0V, else low (0V) otherwise.
- Start trigger (green) Produces a 1ms trigger upon entry to the Fall stage. The trigger may be shortened upon exit from the Fall stage.
- End trigger (red) Produces a 1ms trigger upon exit from the Fall stage. The trigger may be shortened upon rentry to the Fall stage.
- EOC (end of cycle) trigger (orange) Produces a 1ms trigger when the Fall stage reaches 0V. The trigger is not fired if the envelope is retriggered before reaching 0V.
The envelopes are output here. The small button beside the label configures the voltage range of the envelope.
- Unipolar (green, default) Normal envelope from 0V to 10V
- Inverted unipolar (orange) Inverts the envelope from 10V to 0V
- Bipolar (red) Offsets the envelope by -5V for a +/-5V range
Retrigger and ASR Rise behavior can be modified by patching one or more of the stage gate outputs into the TRIG and/or GATE inputs. These configurations take advantage of VCV's stackable input ports. Note that the patched stage output(s) must be configured to produce a gate for these configurations to work.
Mode | Feedback | AD Trig Rise To Full |
AD Trig Rise Retrigger |
AD Trig Sustain At Full |
AD Trig Fall Retrigger |
ASR Gate Rise To Full |
ASR Gate Sustain At Full |
ASR Gate Fall Retrigger |
---|---|---|---|---|---|---|---|---|
1 | None | Yes | No | No* | From current |
While gate high |
While gate high |
From current |
1 | RISE->GATE | Yes | No | No* | From current |
Yes | While gate high |
From current |
1 | RISE->TRIG FALL->TRIG |
Yes | No | No* | No | While gate high |
While gate high |
No |
1 | RISE->GATE SUS->TRIG FALL->TRIG |
Yes | No | No* | No | Yes | While gate high |
No |
* An AD envelope will sustain 10V if a high GATE is received after the AD is triggered by TRIG
Mode | Feedback | AD Trig Rise To Full |
AD Trig Rise Retrigger |
AD Trig Sustain At Full |
AD Trig Fall Retrigger |
ASR Gate Rise To Full |
ASR Gate Sustain At Full |
ASR Gate Fall Retrigger |
---|---|---|---|---|---|---|---|---|
2 | None | Yes | From 0 | No | From 0 | While gate high |
While gate high |
From 0 |
2 | RISE->TRIG | Yes | No | No | From 0 | While gate high |
While gate high |
From 0 |
2 | RISE->GATE | Yes | No | No | From 0 | Yes | While gate high |
From 0 |
2 | RISE->TRIG SUS->TRIG FALL->TRIG |
Yes | No | No | No | While gate high |
While gate high |
No |
2 | RISE->GATE SUS->TRIG FALL->TRIG |
Yes | No | No | No | Yes | While gate high |
No |
All inputs and outputs are fully polyphonic with support for both low frequency and audio rates.
The total number of output channels is determined by the maximum number of channels received across all CV inputs.
Any monophonic CV input is replicated to match the output channel count.
Polyphonic CV input with fewer channels are assigned constant 0V for the missing channels.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are constant monophonic 0V when the AD/ASR Envelope Generator is bypassed.
This expander module adds additional cloned poly input/output pairs to Clone Merge, Poly Clone, or Poly Unison.
The expander must be placed immediately to the right of a Clone Merge, Poly Merge, or Poly Unison. The yellow LED in the upper left indicates whether the expander has successfully connected to a parent module.
Each set of polyphonic input channels is cloned to match the clone count of the parent module, and sent to the output. The number of polyphonic channels at the input should either match the number of input channels at the parent, or else 1. If the input is unpatched it is treated as a mono input with a single chanel at constant 0 volts.
The GRP button above and to the right of each input port controls how the cloned channels will be grouped at the corresponding output
- Input channel (yellow, default) - All the cloned channels for a given input channel will be grouped together at the output.
- Input set (blue) - The input channels will be grouped together in order as a set, and then the set will be cloned at the output.
The number of polyphonic channels at each output will always match the number of poly output channels at the parent. The LED to the right of each output indicates whether the output was able to properly clone all input channels.
If the input poly count matches the parent, then each of the input channels is cloned as per the parent, and the LED is yellow.
If the input poly count is 1, then the input is replicated to match the parent input channel count, and then each of those channels is cloned. The LED is yellow.
If the input poly count is less than the parent and greater than 1, then the missing channels are treated as constant 0V, and the LED is orange.
If the input poly count is greater than the parent, then excess channels are ignored, and the LED is red.
All outputs will be constant 0V and all port LEDS will be black under any of the following conditions:
- The expander is not connected to a parent.
- The expander is bypassed.
- The parent module is bypassed.
The names of each input/output pair are linked. Changing the name of one will automatically change the name of the other.
Â
Â
Bay Input, Bay Norm, and Bay Output are polyphonic transmitter and receiver modules with user defined labels for making clean, self documenting patch bays. They are a great companion for the MindMeld PatchMaster user interface modules.
None of the Bay modules are particularly useful on their own - Each Bay Input should be paired with at least one Bay Output and/or Bay Norm. Each input on a Bay Input is transmitted to the corresponding output on the Bay Output or Bay Norm. Each Bay Norm output has a corresponding Normal input that is used when the source Bay Input is not patched.
Signal Transmission is instantaneous - there is no sample delay introduced between a Bay Input and the linked Bay Output/Norm.
Each Bay module has a context menu option to specify a unique name for the module instance that appears as a label at the top of the module.
Bay Output and Bay Norm each have a context menu option to specify the Bay Input source for that instance. A Bay Output or Bay Norm can only have a single source. But a Bay Input can be the source for multiple Bay Outputs/Norms
The Bay Input source is identified by the numeric VCV module instance ID, shown within parentheses in the context menu. The user defined Bay Input name is displayed before the numeric ID, and makes it easier to keep track of which Input is linked to which Output/Norm. Changing the name of a Bay Input does not break the link.
Each port on a Bay Input/Output/Norm can be given a user defined name via the standard Venom port context menu. The port name is displayed as a label above the port. The label for a Bay Norm output is taken from the output port. The normal input port name only appears in the hover text - it does not appear as a label.
The factory default input port name is always "Port " followed by the port number.
The factory default output port name depends on whether the module has been linked to a source:
- Linked default: Inherits the current name from the source Bay Input port
- Unlinked default: "Port " followed by the port number
The factory default is always the current output port name with "normal" appended.
Bay Output and Bay Norm have an "Enable 0 Channel output" context menu option. If this option is enabled, then a Bay Output output will have 0 channels if the source Bay Input is not patched or there is no link. A Bay Norm output will have 0 channels if both the source input and the normal input are not patched or if there is no link.
If the option is not enabled then the output would be constant monophonic 0 volt instead.
Cables with 0 channels act as though there is no patch cable at all, so normalled inputs at the destination input are preserved.
The Bay modules work fine when used with Rack Pro running as a plugin within a DAW. However, Bay Output and Bay Normal can only link to Bay Input sources within the same plugin instance. They cannot link across multiple plugin instances, whether they be in the same or different tracks.
Place the Bay Input in your patch bay with a name of "Input n" where n is a sequential number.
Give each of the Bay Input ports a descriptive name designating the use for the port.
Place the destination Bay Norm in the "operational guts" of your patch, and give it a name of "Target n".
Map the Target n source to the corresponding "Input n" in your patch bay.
Leave all Bay Norm ports with factory default names so the labels are automatically inherited from the source.
Patch the output ports to the correct inputs in your operational patch. Patch the default values to the normal inputs.
Place a Bay Input near the operational guts of your patch and give it a name of "Source n", where n is a sequential number.
Give each of the "Source n" ports a descriptive name designating the use of the patch bay output.
Patch each signal source in your operational patch to the appropriate input port in your "Source n"
Place a Bay Output in your patch bay and give it a name of "Output n" where n matches the number of the source.
Map the output to the corresponding "Source n" in your operational patch.
Leave all patch bay output ports with their factory default names so they inherit the name from the source.
Custom module and port names are always preserved when duplicating, pasting or importing a selection set.
If duplicating, pasting, or importing a linked pair of modules, then the output modules are linked to the copied sources.
If duplicating, pasting, or importing linked output modules without the sources, then an attempt is made to link the outputs to the original uncopied sources.
No values are teleported from a Bay Input to a Bay Output/Norm if either module is bypassed.
All Bay Output ports will be constant monophonic 0 volts if the Bay Output is bypassed or the source Bay Input is bypassed.
The Bay Norm output will be the normal input if the source Bay Input is bypassed. The Bay Norm output will be monophonic constant 0 volts if the Bay Norm is bypassed.
A complex chaotic oscillator emulating the oscillator and rungler components of a Benjolin. It produces 7 outputs: two pairs of triangle and pulse waves with exponential FM, two varying width pulse outputs, and a stepped voltage output similar to a random sample & hold. Frequency range is very wide, from slow LFO rates to high audio rates. Connect a resonant filter with excellent ping characteristics, and you have a complete functional Benjolin.
The Benjolin was invented by Rob Hordijk in 2009. It is a non-traditional / experimental electronic musical instrument that uses a small number of simple circuits and a minimal number of knobs to create an astonishing range of sounds and patterns. Extensive use of feedback and cross-modulation makes the Benjolin a chaotic sound source, with the ability to create stable patterns as well.
There have been many variations of the Benjolin, but the basic functional architecture is always the same - two oscillators, a specialized shift register construct called the Rungler, and a resonant state variable filter. This module is based on the Eurorack version 2 of the Benjolin created by After Later Audio in collaboration with Rob Hordijk.
Some day I would like to create a complete Benjolin module, but I do not yet have the kowledge to program a resonant filter worthy of the Benjolin. So this module only includes the two oscillators and the Rungler. A complete fully functioning Benjolin patch can be created by pairing the Benjolin Oscillator with a resonant filter module.
The module is arranged in three vertical sections: OSC1, OSC2, and RUNGLER.
The oscillators are digital with triangle and pulse outputs. They are intentionally not exactly 1V/Octave.
Sets the base frequency of oscillator one. Fully counterclockwise is roughly 0.03 Hz (30 seconds per cycle). The oscillator cannot be modulated below this minimum frequency. The oscillator remains in LFO territory up through noon at about 15 Hz. A bit above that and it transitions to audio rates, with a maximum fully clockwise frequency of around 7.8 kHz without any modulation. With modulation the oscillator maximum frequency is about 12.5 kHz.
Controls how much the rungler signal modulates oscillator 1 frequency. The knob is a bipolar attenuverter ranging from -1 (100% inverted) to 1 (100%), with the default noon value of 0 (no modulation).
Bipolar input with a bipolar attenuverter to modulate oscillator 1 frequency. The attenuverter ranges from -1 (100% inverted) to 1 (100%), with the default noon value of 0 (no modulation).
The CV1 input is normalled to the Oscillator 2 triangle output.
Triangle waveform bipolar output for oscillator one, ranging from -5 to 5 volts.
Pulse waveform bipolar output for oscillator one, ranging from -5 to 5 volts.
Sets the base frequency of oscillator two. Fully counterclockwise is roughly 0.03 Hz (around 30 seconds per cycle). The oscillator cannot be modulated below this minimum frequency. The oscillator remains in LFO territory up through noon at about 15 Hz. A bit above that and it transitions to audio rates, with a maximum fully clockwise frequency of around 7.8 kHz without any modulation. With modulation the oscillator maximum frequency is about 12.5 kHz.
Controls how much the rungler signal modulates oscillator 2 frequency. The knob is a bipolar attenuverter ranging from -1 (100% inverted) to 1 (100%), with the default noon value of 0 (no modulation).
Bipolar input with a bipolar attenuverter to modulate oscillator 2 frequency. The attenuverter ranges from -1 (100% inverted) to 1 (100%), with the default noon value of 0 (no modulation).
The CV2 input is normalled to the Oscillator 1 triangle output.
Triangle waveform bipolar output for oscillator two, ranging from -5 to 5 volts.
Pulse waveform bipolar output for oscillator two, ranging from -5 to 5 volts.
This small color coded switch controls how much oversampling is applied to reduce aliasing artifacts in the outputs.
- Off (gray)
- x2 (yellow)
- x4 (green)
- x8 (light blue - default)
- x16 (dark blue)
- x32 (purple)
Aliasing might not be noticeable with chaotic and/or low frequency outputs. But the aliasing can become painfully obvious when producing high frequency coherent output unless oversampling is used. But oversampling is rather CPU intensive, so you want to use the minimum amount that gives good results. An oversample value of x8 uses reasonable CPU with VCV running at 48 kHz, and provides clean output in all but the most extreme cases.
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
Due to float arithmetic limitations, the oscillators would stall at the lowest frequency if the VCV sample rate is set above 48 kHz and high oversample rates are used. To compensate, the maximum allowed oversampling is reduced as the VCV sample rate increases. This enables the oscillators to cover their full range regardless what VCV sample rate is used.
The Rungler consists of an eight step shift register driven by a clock and a data input, along with comparators, logic gates, and a digital to analog converter (DAC). The rungler data input is always derived from the oscillator 1 triangle output. The clock input defaults to the oscillator 2 pulse output, but may be overridden at the clock input. When a bit shifts out of the shift register, it is XORed with the data input and fed back into the low bit of the ASR. The Rungler produces multiple output signals. Depending on configuration and the incoming data, the rungler output may be chaotic, or it may have a readily recognized pattern.
By default the Benjolin Oscillator DAC is configured to use bits 2,4,7 in order to maximize the number of available Rungler patterns. There is a module context menu option to use Rob Hordijk's original design of bits 6,7,8.
Above the Rungler label are eight LEDs representing the shift register bits. The DAC LEDs glow bright yellow when high. The remaining LEDs glow dim yellow when high.
Controls whether the Rungler repeats a pattern or is chaotic. When fully anticlockwise, the Rungler produces an 8 step pattern. When fully clockwise it produces a 16 step pattern, with the first 8 steps being a mirror image of the second 8 steps. At noon the rungler output is chaotic.
Below is a technical discussion of how it works.
The Pattern knob range is from -1 to 1, with a default of 0 at noon. The raw internal triangle signal also ranges from -1 to 1. If the Pattern value is greater than the instantaneous incoming triangle value, then the rungler input is high (1), else the input is low (0). The input is XORed with the recycled shift register bit. So a high input inverts the recycled bit, and a low input preserves the recycled bit.
When the Pattern knob is fully counterclockwise, the input is guaranteed to be zero, the recycled bit is preserved, and an 8 step pattern is established.
When the Pattern knob is fully clockwise, the input is guaranteed to be 1, the recycled bit is inverted, and a 16 step pattern is established.
At noon there is a roughly 50-50 chance of 0 or 1, so the rungler output is at its most chaotic, typically with no recognizeable pattern.
If enabled, the Pattern knob is ignored, and the rungler output is always chaotic. Each press of the button toggles the state of the chaos button. The leading edge of a trigger at the input will also toggle the button state.
The Chaos button works by converting the 8 step shift register into a 127 step linear feedback shift register, and by ignoring the Pattern knob and always comparing against 0, so there is always a 50% chance of inversion of the recycled bit.
If Chaos is off, then the rungler may fall into a pattern over time, even if the Pattern knob is at noon. The Chaos button is useful for re-introducing chaos into the output.
If enabled, the Rungler is triggered at double the rate. Normally the Rungler is triggered by the leading edge of a clock gate. When in Double mode the Rungler is triggered by both the leading and trailing edges of a clock gate.
Each press of the Double button toggles the state of the button. The leading edge of a trigger at the input will also toggle the button state.
This is the input that triggers the Rungler. It expects a bipolar clock input, with a high state detected above +1V, and a low state below -1V.
If oversampling is enabled, then interpolation of square unipolar clock input will have enough "bounce" to reset to a negative state. But square unipolar clocks will not work if oversampling is off. Nor will unipolar sine or triangle waves work regardless of oversampling status. There is a "Unipolar clock input" module context menu option available to work with any unipolar clock input.
The Clock input is normaled to the Oscillator 2 pulse output.
This is simply the first bit of the Rungler shift register, scaled and offset to be bipolar +/-5V.
Although this is under the Rungler section, it actually has nothing to do with the Rungler. This bipolar +/-5V output is produced by a comparator that outputs 5V when the TRI2 signal is greater than TRI1, and -5V otherwise. This is the signal that traditionally gets sent to the Benjolin filter input. It was called PWM by Rob Hordijk because it produces a series of variable width pulses, reminiscent of a pulse wave with pulse width modulation.
This output is also bipolar varying between +/-5V. It is a stepped voltage signal with 8 possible values created by the digital to analog converter in the Rungler.
The original release of the Benjolin Oscillator had CV1, CV2, and Clock normalled values that were 20% of what they should have been. This bug has been fixed, but just in case there are existing patches that depended on the original normalled values, there is a module context menu option "Original release normalled values" that uses the old values when enabled. Patches with the Benjolin Oscillator that were created using the original release will default to having this option enabled.
A minimal complete Benjolin can be patched simply by pairing the Benjolin Oscillator with a resonant filter with good ping characteristics. I find the Vult Unstabile filter works extremely well. Simply patch the PWM output to the filter input, and the Rungler output to the filter cuttoff input.
A Benjolin should not self oscillate unless given feedback from the filter band pass output. So ideally the cutoff frequency and resonance amount should be constrained so as to prevent self oscillation. Other things to consider are a crossfade module to allow a mix of PWM and external CV (or self patched CV) as input to the filter. Also a mixer would be good to allow a mix of external (or self patched) CV and Rungler input to the Cutoff frequency.
The patch below closely emulates the features of the Benjolin version 2 from After Later Audio. A version of the patch wired up as a walking bass line is available at https://patchstorage.com/venom-2-8-benjolin-walking-bass/
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are constant monophonic 0V when the Benjolin Oscillator is bypassed.
Adds additional Rungler gate outputs to the Benjolin Oscillator.
Any number of Gates expanders may be used. All expanders must be placed to the right of the Benjolin Oscillator in a contiguous chain. The upper left LED glows yellow when the expander is successfully connected to a base module.
Note the gate outputs do not participate in oversampling.
This color coded button controls the timing and length of the gate outputs:
- Gate (white, default) - The gate is high as long as the gate logic is true
- Clock gate (yellow) - The gate is high when the gate logic is true and the Rungler clock is high
- Inverse clock gate (orange) - The gate is high when the gate logic is true and the Rungler clock is low
- Trigger (green) - A trigger is sent when the gate logic transitions to true
- Clock rise trigger (light blue) - A trigger is sent when the Rungler clock transitions to high while the gate logic is true
- Clock fall trigger (dark blue) - A trigger is sent when the Rungler clock transitions to low while the gate logic is true
- Clock edge trigger (purple) - A trigger is sent when the Rungler clock tranitions to high or low while the gate logic is true
Triggers are high for 1 msec. But if using a clocked trigger and the clock goes low before the trigger has completed, then the trigger immediately goes low.
This color coded button controls the polarity of the gates
- Unipolar (green, default) - Low = 0V and high = 10V
- Bipolar (purple) - Low = -5 V and high = 5 V
The LED in the upper right corner of each output port glows yellow whenever the output gate is high.
Each output port has a context menu to specify which Rungler bits are used, and what logic operator to use. By default the gate logic is used for the port name, and displayed as a label above the port.
You may select up to 4 bits. Once 4 have been selected you cannot select another without first unselecting one.
You must select one of three options:
- AND (&) - The gate logic is true if all selected bits are high
- OR (|) - The gate logic is true if at least one selected bit is high
- XOR (^) - The gate logic is true if exactly one selected bit is high
If only one bit is selected, then all logic operations give the same result - the logic is true if the selected bit is high.
There are four factory presets that default to mode = Gate and polarity = Unipolar
- All Bits - There is one gate for each Rungler bit
- AND Gates - AND logic is used with bits 1&2, 2&4, 4&7, 1&2&4&7, 2&3, 3&5, 5&8, 2&3&5&8
- OR Gates - OR logic is used with bits 1|2, 2|4, 4|7, 1|2|4|7, 2|3, 3|5, 5|8, 2|3|5|8
- XOR Gates - XOR logic is used with bits 1^2, 2^4, 4^7, 1^2^4^7, 2^3, 3^5, 5^8, 2^3^5^8
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are constant monophonic 0V when the Benjolin Gates Expander is bypassed.
Adds an additional Rungler CV output to the Benjolin Oscillator. It works as a configurable digital to analog converter.
Any number of Volts expanders may be used. All expanders must be placed to the right of the Benjolin Oscillator in a contiguous chain. The upper left LED glows yellow when the expander is successfully connected to a base module.
Note the output does not participate in oversampling.
If on (white), then the Bit knobs snap to powers of 2. If off (gray) then the knobs can be freely set to any decimal value betwen 0 and 128.
Each knob represents a Rungler bit. The knob assigns a value to the bit between 0 and 128. Knobs (bits) set to 0 do not participate in the digital to analog conversion. The assigned values for all high Rungler bits are summed, and then scaled and offset to a bipolar +/- 5V range (10 VPP).
Scales the peak to peak range of the output to any value between 0 and 10V.
Offsets the output by any value between -10V and 10V. The Offset is applied after the Range.
The final computed voltage is ouput here.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
The output is constant monophonic 0V when the Benjolin Volts Expander is bypassed.
The Bernoulli Switch stochastically routes two inputs to two outputs.
Upon receiving a trigger or gate, a virtual coin toss determines if input A goes to output A and B to B (no-swap), or if A goes to B and B to A (swap). Each input can be attenuated and/or inverted by a bipolar SCALE knob ranging from -1 to 1, and offset by an OFFSET knob, ranging from -10 to 10. The A input is normalled to the TRIG input and the B input is normalled to 0V, so if both inputs are left unpatched, the Bernoulli Switch will function as a "traditional" Bernoulli Gate. A "latched" mode may be achieved by leaving the B input at 0V and setting the A input SCALE to 0 and the A OFFSET to 10V.
The PROB knob and PROB input determine the probability that a particular routing operation will occur. If there is no PROB input, then a fully counterclockwise PROB knob yields a 0% chance of the the routing operation, and fully clockwise is 100% chance. The range is linear, with 50% at noon. The probability can be modulated by bipolar PROB input, with each volt equating to 10% chance.
The actual routing operation is controlled by the unlabeled 3 position sliding switch, with the following possible values:
- TOGGLE: The probability is the chance that the routing will toggle from the current routing to the opposite. If currently swapped, then a positive result will switch to un-swapped. If currently unswapped, then a positive result will switch to swapped. A negative result yields no change.
- SWAP: The probabiliy is the chance that the routing will be set to swapped, regardless of the current routing. A positive result yields a swapped routing, a negative result yields a no-swap routing.
- GATE: The routing is always in a swap configuration whenever the TRIG input is low. Upon transition to high, a positive coin toss results in a no-swap routing throughout the TRIG high state. A negative result remains in a swap configuration.
The module generally responds to a leading edge transition from low to high of the TRIG input or the manual TRIG button. The TRIG button works by adding 10V to the TRIG input.
Bernoulli Switch uses Schmitt trigger logic to determine when a trigger starts and stops. The RISE knob sets the threshold for a trigger transition to high, and the FALL knob sets the threshold for a transition to low. By default the RISE is set to 1V, and the FALL to 0.1V. If currently low, then a TRIG input >= the RISE threshold transistions to HIGH. The input remains high until the input falls below the FALL threshold, upon which it returns to a low state.
If the RISE threshold is less than the FALL threshold, then the roles are reversed, and the Bernoulli Switch is triggered by a trailing transition from high to low. If using GATE mode, the routing will always have a swap configuration whenever the input is high, and the configuration may switch to no-swap upon transition to low.
The TRIG button is not guaranteed to always trigger a coin toss - it depends on how the RISE and FALL are configured, as well as the current TRIG input value.
The small color coded button next to the Trig input determines exactly what value is normalled to the A input.
- Raw trigger input - red (default): The trigger input is passed unmodified
- Schmitt trigger result - blue: The Schmitt trigger gate is sent instead of the raw input. A low state is always 0V. Normally a high state is 10V. But the "high" gate will be -10V if the rise threshold is below the fall threshold.
Bernoulli Switch is fully polyphonic. There are two modes available from the context menu that determine how many virtual coin tosses are performed based on the number of channels on each input:
-
TRIG and PROB only (default)
The number of coin flips is the maximum channel count found across the TRIG and PROB inputs. If one of the inputs is monophonic, and the other polyphonic, then the monophonic input is replicated to match the channel count of the polyphonic input. If a polyphonic input is missing channels, then the missing channels are treated as 0V.
If the coin flip count is 1 (both TRIG and PROB are mono), then polyphonic inputs to A and/or B are treated as a whole - all of the channels on the A input are directed to either the A or B output. The same for the B input. If either A or B input has fewer channels than the other, then the missing channels are made up with 0V so that A and B always send the same number of channels.
But if either of TRIG or PROB are poly, resulting in multiple coin flips, then each coin flip is applied to the appropriate channels in A and B inputs. This can result in A and B input channels being scrambled across the A and B outputs. Monophonic A and/or B inputs are replicated to match the coin flip channel count. Missing channels in polyphonic A and/or B are treated as 0V. Extra input channels in A or B are ignored.
-
All inputs
The number of coin flips is the maximum channel count found across all four inputs - TRIG, PROB, A, and B. Monophonic inputs are replicated to match the maximum channel count. Polyphonic channels with missing channels treat the missing channel as 0V.
Polphonic inputs in A and/or B can always be scrambled across A and B outputs.
A small LED between the INPUT ports glows yellow when polyphony detection is configured for "All inputs". The LED is off (black) when configured for "TRIG and PROB only".
A pair of yellow lights indicate the current routing configuration. A yellow light glowing to the left of the PROB knob indicates a no-swap configuration. A glowing yellow light to the right indicates a swap configuration.
The yellow lights only monitor a single channel - by default they monitor channel one. The context menu has a Monitor Channel option to switch to a different channel. If the monitored channel is Off, or greater than the number of coin flip channels, then the yellow lights will remain dark - no monitoring will be done.
By default Bernoulli Switch is configured for switching gates or CV signals, but it can also process audio signals. If you switch audio at slow rates you may get unwanted pops. If you switch audio at audio rates then you may get unwanted aliasing. The module context menu has Audio Process options to reduce or eliminate these artifacts: Antipop crossfade for slow switching, and various oversampling options for audio rate switching. A small LED between the OUTPUT ports glows red when Anti-Pop Switching is in effect, and blue when any of the oversampling options is enabled. The LED is off (black) when the Audio Process is set to Off (the default).
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
The following factory presets are available that emulate the four configurations available to the Mutable Instruments Branches module:
- Bernoulli Gate - Sends 10V Schmitt trigger gate to A or B
- Latched Bernoulli Gate - Sends constant 10V to either A or B
- Latched Toggled Bernoulli Gate - Toggles constant 10V between A and B
- Toggled Bernoulli Gate - Toggles 10V Schmitt trigger gate between A and B
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If Bernoulli Switch is bypassed then the A input is passed unchanged to the A output, and likewise the B input to the B output. The B input is still normalled to the A input while bypassed.
Adds CV inputs with attenuverters for all of the Bernoulli Switch parameters, all of which can be driven at audio rates.
The expander must be placed to the right of the Bernoulli Switch. The LED near the top glows yellow when a successful connection is made.
All the expander inputs are additive with their associated Bernoulli Switch parameters, with one exception. The mode input supersedes the mode parameter when patched.
- Toggle mode <= -1V
- Swap mode >-1V and <1V
- Gate mode >= 1V
An attenuator for the Bernoulli Switch Probability CV was added rather than an attenuator for the expander mode CV.
All expander CV inputs are monophonic, with the signal applied equally to any polyphony found at the Bernoulli Switch.
None of the expander inputs are oversampled, even if the Bernoulli Switch has oversampling enabled.
All expander inputs as well as the probability CV attenuator are ignored when the expander is bypassed.
Watch this video to see how the Bernoulli Switch coupled with the Bernoulli Switch Expander can transform a simple sine wave into a dynamic complex stereo sound.
Blocks expander chains for modules like Venom Bypass and Stoermelder Strip.
Both Venom Bypass and Stoermelder Strip can operate on contiguous neighbor modules to the left and/or right, up until there is a gap. They locate neighbors via the VCV expander mechanism. Blocker works by hiding itself from the expander mechanism, so Bypass and Strip think there is a gap. Even when Blocker is bypassed, it still blocks expansion.
Blocker uses virtually no CPU, so it also works well as a 1hp blank.
Bypass (disable) one or more modules at the end of patched cables via CV control or a manual button press.
The Bypass module has input/output pairs that simply pass through all channels appearing at the input. However, the Bypass module also has the ability to virtually transmit a message through each cable to bypass the module (or group of modules) at the end of the cable.
The Bypass module maintains its own state, indicating whether it thinks remote modules are bypassed or not. The actual bypass state of the remote module may or may not match the Bypass state because users can directly change the remote module bypass state without using the Bypass module. The Bypass module only changes the remote module bypass state when the Bypass module state changes.
This button glows red when the Bypass state is active (meaning the controlled modules are disabled).
By default, each time the button is pressed, it toggles the current Bypass state.
If the Momentary button is active, then the button temporarily inverts the current Bypass state while it is held, and restores to the previous state when released.
This color coded button controls whether the trigger button acts as a toggle trigger, or a momentary inverting gate.
- Off (gray) (default) - The button toggles the Bypass state each time it is pressed
- On (yellow) - The button momentarily inverts the current Bypass state while it is pressed, and reverts to the prior state when released
This color coded button controls whether trigger CV input acts as a gate or a toggle trigger.
- Off (gray) (default) - Input is a trigger
- On (green) - Input is a gate
- Invert (red) - Input is an inverted gate
If the Gate mode is Off, then the leading edge of a trigger at the CV input will toggle the bypass state on or off.
If the Gate mode is On, then a high gate at the input turns the bypass on, and a low gate turns the bypass off. The gate functions as a Schmitt trigger, going high at 2V, and low at 0.1V. Regardless whether the CV gate is high or low, the Trig button will always toggle the Bypass state.
If the Gate mode is Invert, then a high gate at the input turns the bypass off, and a low gate turns the bypass on. The gate functions as a Schmitt trigger, going high at 2V, and low at 0.1V. Regardless whether the CV gate is high or low, the Trig button will always toggle the Bypass state.
There are three input/output pairs that simply pass any input values through to the output, with full support for polyphonic cables.
Each output port is a bit unusual in that any patched cable will have 0 channels if the corresponding Bypass input port is unpatched. This allows for Bypass to control the bypass state of remote modules, without disturbing any normal value for the remote module input port. The remote module will act as though the cable is not there, yet Bypass will still be able to bypass the remote module.
Each input port has a Bypass mode button above it, and each output port has a Bypass mode button below it. The Bypass mode dictates whether the Bypass module controls the bypass state of the module(s) at the end of patched cables at either port. The Bypass mode buttons are color coded.
Each input Bypass mode button has the following available options:
- Dark gray (default) - Off (no modules are bypassed)
- Purple - Source (Only the input source modules are bypassed)
- Blue - Source and left neighbors (The input source modules and all contiguous neighbors to the left are bypassed)
- Yellow - Source and right neighbors (The input source modules and all contiguous neighbors to the right are bypassed)
- Green - Source and all neighbors (The input source modules and all contiguous neighbors on both sides are bypassed)
Each output Bypass mode button has the following options:
- Dark gray - Off (no modules are bypassed)
- Purple (default) - Target (Only the output target modules are bypassed)
- Blue - Target and left neighbors (The output target modules and all contiguous neighbors to the left are bypassed)
- Yellow - Target and right neighbors (The output target modules and all contiguous neighbors to the right are bypassed)
- Green - Target and all neighbors (The output target modules and all contiguous neighbors on both sides are bypassed)
Every time the Bypass changes state, the relevant remote modules at the end of each cable are set appropriately.
A neighbor chain always terminates at any one of the following
- A gap in the chain
- A Bypass module. The Bypass is not part of the chain.
- A Venom Blocker. The Blocker is not part of the chain.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
Clone Merge clones up to 8 monophonic inputs and merges the resultant channels into a single polyphonic output. It is especially useful with the Recurse modules when using polyphonic inputs. Clone Merge provides a convenient way to replicate CV inputs to match the recursion count.
Up to four auxilliary poly inputs may also be cloned via the Auxilliary Clone Expander.
Selects the number of times to clone or replicate each input. Possible values range from 1 to 16.
The 8 monophonic inputs should be populated from top to bottom. Each input is replicated based on the Clone count as long as the total channel count across all replicated inputs does not exceed 16. Inputs that cannot be replicated the full amount are ignored.
An LED glows yellow for each input that is successfully replicated. The LED glows red if the input cannot be replicated. Unpatched inputs below the last patched input are ignored and the corresponding LED is off (black).
The GRP controls how the cloned inputs will be grouped at the corresponding output
- Input channel (yellow, default) - All the clones for a given input will be grouped together at the output.
- Input set (blue) - The inputs will be grouped together in order as a set, and then the set will be cloned at the output.
All of the replicated inputs are merged into the single polyphonic output. The order of the channels is dependent on the GRP button.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If Clone Merge is bypassed then the output is constant monophonic 0V.
Eight inputs in three dimensional space are cross faded to a single output. The inputs are placed at the vertices of a virtual cube. X, Y, and Z controls independently cross fade between inputs on opposite faces of the cube. Each fader functions linearly in amplitude, ranging from 0% to 100%. The orthogonal faders are multiplicative, such that when all three controls are at an extreme, then 100% of the output comes from a single input. When all three controls are at 50% then each input contributes 12.5% to the output. A final Level control can further attenuate the final output.
Every input and output is fully polyphonic. The output channel count is the maximum channel count found across all inputs. Monophonic inputs are replicated to match the final output channel count. Polyphonic inputs with fewer channels use constant 0V for any missing channels.
The faceplate has a perspective view of a cube with a polyphonic input at each of the eight vertices. The inputs are not individually labeled on the faceplate, but when you hover over an input a name is displayed that identifies whether the input is left or right, bottom or top, and front or back.
If only the Bottom Left Front input is patched, then Cross Fade 3D treats the input as an 8 channel polyphonic signal where each channel represents a monophonic input for one of the cube vertices. Missing channels are assigned constant 0V. The 8 channels are assigned as follows.
- 1 = Bottom left front
- 2 = Bottom right front
- 3 = Top left front
- 4 = Top right front
- 5 = Bottom left back
- 6 = Bottom right back
- 7 = Top left back
- 8 = Top right back
X controls the left to right ratio, and is measured as percent right.
Y controls the bottom to top ratio, and is measured as percent top.
Z controls the front to back ratio, and is measured as percent back.
Each fader control ranges from 0% to 100%, with the default 50% at noon.
Each dimension has a bipolar CV input and dedicated attenuator. The CV is scaled at 10% per volt by default. The CV is summed with the control value and clamped to a value between 0% and 100%. With a dimension at 50% and the CV attenuator at 100%, a +/- 5V bipolar can modulate a dimension from one extreme to the other.
A module context menu option is available to scale the CV at +/- 200% instead of +/- 100%. This enables a simple bipolar +/- 5V sine or triangle modulator to transition to one extreme and hold, before transitioning in the other direction.
If you prefer to work with spherical coordinates, then the Sphere To XYZ module is available to convert r, theta, phi spherical coordinates into X, Y, Z cartesian coordinates.
By default, polyphonic channels are preserved at the output. If the Mono Output button is enabled, then polyphonic output channels are summed to a monophonic output signal.
The final output level can be attenuated with the Level control. This may be especially useful when working with polyphonic inputs that are summed to a mono output.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
The output is constant monophonic 0V if the module is bypassed.
Computes a selected harmonic or subharmonic partial relative to a fundamental root V/Oct, or quantizes an input V/Oct to the nearest partial relative to the root.
This module is fully polyphonic. The number of output channels is the maximum channel count found across all three inputs. Any monophonic input is replicated to match the output channel count. A polyphonic input with fewer channels uses 0V for any missing channels.
Displays the integral partial number that is currently being output for a single channel. A yellow value indicates a positive value, representing a true partial from the natural harmonic series. A red value indicates a negative value, representing a subharmonic.
By default the display monitors channel 1. A different channel may be selected via the module context menu. The display will be blank if the selected channel is Off, or greater than the number of output channels.
Selects one of three possible series
- A = All partials - (default)
- O = Odd partials
- E = Even partials (includes the fundamental partial, even though it is odd)
The output will be constrained to the selected series.
Selects a single integral partial number. By default the range is from 1 (fundamental) to 16 (4 octaves above the fundamental). The context menu allows selection of any one of the following ranges:
- 1 to 16 (default)
- 1 to 32
- 1 to 64
- 1 to 128
- -16 to 1
- -32 to 1
- -64 to 1
- -128 to 1
- -16 to 16
- -32 to 32
- -64 to 64
- -128 to 128
Negative values refer to subharmonics. There is no 0 partial, and both -1 and 1 refer to the same fundamental root. So both 0 and -1 are skipped within the sequence of allowable values.
The bipolar CV input modulates the selected partial, adding or subtracting 1 partial for every 0.1 volt. The CV input is attenuated and/or inverted by the CV knob. The resultant partial is clamped to within the currently active Partial range. Keep in mind that 0 and -1 are skipped when computing the end result, so a knob value of -2 + 0.1 volt modulation yields 1, not -1.
The Partial knob, CV knob, and CV input are all ignored if the IN input is patched (although the CV input can still modify the number of output channels).
Harmonics (integral ratios) are often used to create harmonious results with things like frequency modulation, phase modulation, and ring modulation. But if the harmonic is detuned slightly, it can give a richer sound, much like detuned unison voises. The result often has a beat tone. If the amount of detune (measured in cents) remains constant, the beat tone frequency increases as the pitch rises. If the degree of detuning is halved for every rise of one octave, then the beat tone rate remains constant across all frequencies.
This bipolar knob sets the base amount of detuning. The default at noon gives no detuning. Turning to the left (counterclockwise) detunes to lower frequencies, and to the right (clockwise) detunes to higher frequencies.
This unipolar knob controls how much compensation is applied to keep the detuned beat tone rate more constant as frequency changes. The fully counterclockwise value of 0 applies no compensation - the detune amount remains constant at all frequencies, and the beat tone rates vary the most. The fully clockwise value of 1 decreases the detune amount by 1/2 for every octave rise, and the beat tone rate remains constant at all frequencies.
Establishes the fundamental V/Oct value (1st partial)
If this port is patched, then the V/Oct input is quantized to the nearest harmonic or subharmonic partial relative to the ROOT input. The computation is clamped to within +/- 128 partials (+/- 7 octaves). The Partial knob, CV knob, and CV input are all ignored when quantizing IN input.
The final computed partial is converted into a delta V/Oct and added to the ROOT to establish the final output V/Oct value.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
The IN input is passed unchanged to the OUT output when the Harmonic Quantizer is bypassed.
Five independently configurable constant voltage knobs.
Each knob has custom menu options to tailor the knob to your needs.
Determines the minimum and maximum voltage of the knob.
- 0-1 V
- 0-2 V
- 0-5 V
- 0-10 V
- +/- 1 V
- +/- 2 V
- +/- 5 V
- +/- 10 V (default)
- Custom
If Custom is chosen, then two menu options are added to set the custom range: Custom min for the full counter-clockwise level, and Custom max for the full clockwise level. The min and max values can range from -100 to 100. You can enter simple mathematical expressions - all of the keyins that work for setting a knob value also work for the custom levels. You are free to set the min greater than the max so the knob works in reverse.
Determines how knob values are quantized.
- Off (continuous) (default)
- Integers (octaves)
- 1/12 V (semitones)
- Custom interval
If Custom interval is chosen, then a Custom quantize interval menu option is added to set the custom interval. The interval can be any positive value up to 100. You can enter simple mathematical expressions - all of the keyins that work for setting a knob value also work for the custom interval. If you enter a value less than or equal to zero, then the value will be transformed into 1.
Determines how knob values are displaed and entered in knob context menu and hover text. Output values are always in Volts.
- Volts (V) (default)
- Cents (¢)
Determines the number of polyphonic channels to output. All channels will be identical. The default is 1 (mono).
The module context menu includes options to configure all knobs simultaneously. The option values are the same as for individual knobs except custom values are not supported. You must configure each knob individually if you want custom values.
If all knobs currently share the same value, then the current value is displayed in the menu. If at least one knob is different, then the current value is empty.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus. However, the rename function is modified slightly. Renameing a knob will automatically rename the corresponding output port, and vice versa.
All outputs are constant monophonic 0 V when KNOB 5 is bypassed.
Only allow one trigger/gate to strike at a time across multiple incoming trigger/gate channels, thus converting coincident drum triggers into a linear drumming pattern.
Lower lettered inputs (toward the top) take precedence over higher lettered inputs (toward the bottom). Linear Beats is polyphonic, and lower numbered polyphonic channels take precedence over higher numbered channels.
A gate/trigger appearing at the input may or may not be passed through to the output depending on the channel mode, and whether or not a higher precedence channel transitioned to high at the same time. A lower precedence channel in Linear mode may strike a new gate while higher precedence gates are high as long as none of those higher precedence gate transitions are coincident.
For example, in the image below the top oscilloscope shows gate patterns with coincident gates. The bottom oscilloscope shows the effect of Linear Beats - lower precedence gates with coincident transitions to high are removed. Note that Rhythm Explorer has linear beats capabilities built in that this example does not use. The Linear Beats module just brings that functionality to a stand-alone module.
Each channel has four possible modes controlled by a color coded button:
- Linear (green) - Any gate will not pass through if a higher precedence gate transitioned to high at the same time. Any gate that does pass through will block lower precedence gates.
- All (off, dark gray) - All gates will pass through, regardless whether higher precedence channels transitioned to high at the same time. All gates will block lower precedence gates.
- Non-blocking Linear (orange) - Any gate will not pass through if a higher precedence gate transitioned to high at the same time. Gates that do pass through will not block lower precedence gates.
- New All (white) - All higher precedence gates are forgotten and a new linear drumming group is started. All gates will pass through and also will block lower precedence gates.
There does not exist a Non-blocking All mode. If you want to allow gates through that do not block lower precedence channels, then simply put that channel toward the top and start a new linear drumming group with a New All mode below.
A channel mode applies identically to all polyphonic channels on a given lettered channel.
All inputs are Schmitt triggers that transition to high when the level rises to 1V or above, and transition to low when the level falls to 0.1V or lower. The outputs are 10V for high, and 0V for low.
If Linear Beats is not clocked, then it is dependent on all trigger/gate transitions being exactly in sync down to the sample level.
If the input gates are not guaranteed to be in sync, then you can add a clock input to effectively force all triggers/gates to be in sync with the timing "grid" of the clock. Inputs are only checked for transition to high or low whenever the clock transitions to high. The clock should be delayed at least as much as the most delayed input. If you want outgoing gates to be 50% duty cycle, then the clock should run at least twice as fast as your fastest incoming channel.
If Linear Beats is bypassed, then all inputs are passed through unchanged to the outputs.
Add bypass and input/output mutes to Linear Beats.
The Linear Beats expander can be placed to the left or right of a Linear Beats module. Left expanders apply mutes to the inputs, so that muted channels never block lower precedence channels. Right expanders apply mutes to the outputs so that muted channels can still block lower precedence channels.
If an expander is sandwiched between two Linear Beats, then it will preferentially connect to the right as an input mute.
A single Linear Beats can make use of both input and output mutes simultaneously.
Two small LEDs at the top of the expander indicate which direction, if any, the expander is connected. The LED glows yellow when connected.
A channel is muted whenever the mute button glows red. Pressing a mute button is guaranteed to toggle the mute state. Each mute can also be controlled via CV. An "Expander CV toggles button on/off" context menu option on the main Linear Beats module controls how the CV operates.
- If enabled, then the corresponding button toggles on or off whenever the CV input transitions to high.
- If disabled (default), then the corresponding button is turned on (muted) when the CV transitions to high, and turned off (unmuted) when the CV transitions to low.
In addition to mutes, the expander has a Disable button / CV input pair that turns off linear drumming, allowing all input triggers/gates to pass through, without syncing to any clock. The Disable CV operates the same as for the mutes. If a Linear Beats has both an input and output expander, then disabling either side will disable the linear drumming. Note that disabling Linear Beats is not quite the same as bypassing Linear Beats because the expander mutes are still active when Linear Beats is disabled.
An expander is ignored if it is bypassed.
The Logic module provides up to 9 independent polyphonic logic gates that can be configured for any of the standard logic operations. All logic gates support one, two, or more inputs. A merge option allows polyphonic input channels to be used as inputs for the same logic gate. Compound logic operations can be created by reusing earlier outputs as inputs, without introducing sample delays. Options for oversampling, output range, and DC offset removal make Logic ideal for audio applications, with undesired aliasing limited by the oversampling.
Controls how polyphonic inputs are handled.
- Off (gray - default): Each polyphonic channel gets its own logic gate. The number of output channels is the maximum channel count found across all inputs for that gate. Monophonic inputs are replicated to match the output channel count. Polyphonic inputs with fewer channels assign constant 0V to the missing channels.
- On (white): All logic gate outputs are monophonic. Polyphonic input channels are collected as separate inputs to a single monophonic gate.
Controls how much oversampling is applied to reduce aliasing when using the output as an audio signal. Oversampling can be CPU expensive, so should be off for normal CV usage. For audio applications, the least amount of oversampling should be used that gives satisfactory results.
- Off (gray - default)
- 2x (yellow)
- 4x (green)
- 8x (light blue)
- 16x (dark blue)
- 32x (purple)
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
Controls the output voltages used for high and low states. Unipolar outputs are typically used for CV, and bipolar for audio.
- 0-1 (yellow): unipolar low = 0, high = 1
- 0-5 (green): unipolar low = 0, high = 5
- 0-10 (dark blue - default): unipolar low = 0, high = 10
- +/- 1 (pink): bipolar low = -1, high = 1
- +/- 5 (orange): bipolar low = -5, high = 5
- +/- 10 (purple): bipolar low = -10, high = 10
Controls whether DC offsets are removed from the outputs
- Off (gray - default): Used for normal CV outputs
- On (white): Useful for audio outputs
Set the low and high thresholds for the Schmitt triggers that determine the state of each input. The effective threshold is the sum of the knob value and the corresponding input. The same thresholds are used for all inputs. An input goes high whenever the voltage rises above the high threshold. The input goes low whenever the voltage is at or below the low threshold. The state remains unchanged if the voltage lies between the thresholds.
The module automatically swaps the high and low thresholds if the high falls below the low, so the effective high threshold is always guaranteed to be greater than or equal to the low threshold.
The Low Threshold knob factory default is 0.1V, and the High Threshold knob default is 2V.
There are nine rows, each consisting of two inputs, a Reuse button to recycle a previous output as an additional input, an Operation button to set the output logic, and an output for the logic result. The operation may be set to "defer" so that the row inputs are included as inputs to the row below, and the deferred row output is effectively disabled.
Provide up to two inputs for each row. An input is ignored if it is not patched.
This button allows any of the logic outputs from rows above to be used as an additional input for the row, without introducing a sample delay. If set to None (three dashes), then the button is ignored. The first row doesn't have any row above, so its value is fixed at None.
If the output selected for reuse is deferred, then it is ignored as an input.
An output can also be used as input by patching an output from one row to input A or B from another row, except the patch cable will introduce a one sample delay.
All operations other than defer have non-standard definitions so that they work with one, two, three, or more inputs. Each logic operation will operate in the standard way if there are exactly two inputs.
- Defer (down arrow - default): All inputs from the row are included as inputs to the row below, and the output is unavailable for reuse. The output for the row will be constant 0V.
- AND: The output is high only if all inputs are high.
- OR: The output is high if at least one input is high.
- XOR 1: The output is high only if exactly one input is high and all others are low.
- XOR ODD: The output is high only if there are an odd number of high inputs.
- NAND: The output is high if at least one input is low.
- NOR: The output is high only if all inputs are low.
- XNOR 1: The output is high unless exactly one input is high.
- XNOR ODD: The output is high if an even number of outputs are high, or if all inputs are low
Note that AND, OR, XOR 1, and XOR ODD will all give the same output if there is only one input. A high input will produce a high output, and low input a low output.
The NAND, NOR, XNOR 1, and XNOR ODD will all function as a NOT operator if there is only one input. A high input will produce a low output, and a low input a high output.
Produces the output for the selected logic operation. The output will be monophonic constant 0V if the operation is deferred, or if there are no inputs.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are monophonic 0V if LOGIC is bypassed.
A compact polyphonic mixer, attenuator, inverter, amplifier, and/or offset suitable for both audio and CV. Module functionality can be extended by a set of Mix Expanders.
There are four numbered inputs, each of which can be attenuated, inverted, and/or amplified by a level knob. The level knobs can be configured to different scales. The modulated inputs are then summed to create a mix that can also be attenuated, inverted, and/or amplified by a mix level knob. Finally there are options to hard or soft clip the mix and/or remove DC offset, before sending the final mix to the Mix output. Oversampling is available for soft clipping to control any aliasing that might otherwise be introduced.
These knobs control the attenuation, inversion, or amplification of the input channels. The exact behavior of the knobs depends on the setting of the Mode button.
The channel inputs that are modulated by the Level knob. Each input may be effectively normalled to a constant CV value, depending on the current Level Mode.
This knob controls the attenuation, inversion, or amplification of the final mix, consisting of the sum of the modulated channel inputs. The exact behavior of the Mix Level knob depends on the setting of the Level Mode button.
The final mix is output here. The final mix output may be clipped and/or have DC offset removed, depending on the settings of the Clip and DC buttons.
The number of output polyphonic channels for the final mix is normally the maximum channel count found across all four channel inputs. Monophonic inputs are replicated to match the output polyphony. But polyphonic inputs with fewer channels than in the output send 0V for any missing channels.
There is one major exception when the Level Mode is set to poly sum. In this mode, polyphonic input signals are summed to a monophonic signal before any modulation.
The color coded mode button determines how the 4 channel and the mix knobs behave. The mode button cycles through 5 possible modes. The button context menu allows direct selection of any mode. Each mode is labeled for audio or CV according to typical usage, but all modes can be applied to both audio and CV.
- Unipolar dB (audio x2) (pink - default): Each knob ranges from -inf dB (0V) to +6.0206 dB (x2 amplification), with the default of 0 dB (unity) at noon. Unpatched channel inputs are normalled to 0V.
- Unipolar poly sum dB (audio x2) (purple): Same as Unipolar audio dB, except polyphonic inputs are summed to a single monophonic signal before being attenuated or amplified by the input level knob. Unpatched channel inputs are normalled to 0V.
- Bipolar % (CV) (green): Each input level knob ranges from -100% (inversion) to 100% (unity) if the channel input is patched, or -10V to 10V constant CV when unpatched. Effectively this means unpatched channel inputs are normalled to 10V. Each input level knob defaults to 0% (or 0V) at noon. The Mix knob always ranges from -100% to 100%, with a default of 100%.
- Bipolar x2 (CV) (light blue): Each input level knob ranges from -2x to 2x if the channel input is patched, or -10V to 10V constant CV when unpatched. Effectively this means unpatched channel inputs are normalled to 5V. Each input level knob defaults to 0x (or 0V) at noon. The Mix knob always ranges from -2x to 2x, with a default of 1x (unity).
- Bipolar x10 (CV) (dark blue): Each input level knob ranges from -10x to 10x if the channel input is patched, or -10V to 10V constant CV when unpatched. Effectively this means unpateched channel inputs are normalled to 1V. Each input level knob defaults to 0% (or 0V) at noon. The Mix knob always ranges from -10x to 10x, with a default of 1x (unity).
The color coded DC block button determines when (or if) a high pass filter is applied to the final mix to remove any DC offset. DC offset removal always occurs after the final mix is attenuated (or amplified) by the Mix level knob.
- Off (dark gray - default): DC offset is not removed.
- Before clipping (yellow): DC offset is removed prior to any clipping. Note that subsequent clipping may re-introduce some DC offset.
- Before and after clipping (green): DC offset is removed both before and after any clipping. Note that only one DC offset removal is performed if clipping is not applied.
- After clipping (light blue): DC offset is removed after any clipping.
The last three DC offset options give identical results when no clipping is applied.
The color coded clip button determines how (or if) the final output is clipped.
- Off (dark gray - default)
- Hard post-level at 10V (white)
- Soft post-level at 10V (yellow)
- Soft oversampled post-level at 10V (orange)
- Hard pre-level at 10V (green)
- Soft pre-level at 10V (light blue)
- Soft oversampled pre-level at 10V (dark blue)
- Saturate (Soft oversampled post-level at 6V) (purple)
If clipping is off then there is no limit to the output voltage.
Hard clipping can produce significant aliasing if applied to audio signals.
Soft clipping provides tanh saturation. At moderate saturation levels there is little to no audible aliasing. But very hot signals can still lead to signfcant aliasing.
Soft oversampled clipping also provides saturation, but aliasing is greatly reduced.
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
The MIX output is monophonic 0V if MIX 4 is bypassed.
A stereo compact polyphonic mixer, attenuator, inverter, amplifier, and/or offset suitable for both audio and CV. Module functionality can be extended by a set of Mix Expanders.
Mix 4 Stereo is identical to Mix 4 except each of the inputs and outputs is doubled to support left and right channels so as to support stereo signals. A single input level knob controls each stereo input pair, and a single Mix level knob controls the stereo output pair.
Each right input is normaled to the corresponding left input. When in CV mode, each input level knob produces constant CV only if both the left and right input are unpatched.
The number of polyphonic output channels is determined by the maximum polyphonic channel count found across all inputs. The output channel count always matches for the left and right Mix outputs.
When Mix 4 Stereo is bypassed, both the left and right Mix outputs are monophonic constant CV.
All other behaviors are the same as for Mix 4.
Â
Â
Â
Â
Â
Â
A collection of expander modules that extend the functionality of the four Mix modules: Mix 4, Mix 4 Stereo, VCA Mix 4, and VCA Mix 4 Stereo.
Mix expanders must be placed to the right of the main mix module. Multiple expanders can be used for one mix module as long as they form a contiguous chain to the right. Each expander has an LED in the upper left that glows yellow if successfully connected to a mix module.
A main mix module may have up to 16 expanders. However, any combination of Mix Solo, Mix Mute, Mix Fade, and Mix Fade 2 counts as only one expander toward the 16 expander limit. Also any Mix Offset does not count toward the 16 expander limit.
Bypassing an expander disables that expander without disrupting expanders to the right.
All expanders except Offset are processed after the main Mix input channel Levels are applied, and before the main final Mix level is applied. When used with VCA Mix 4 or VCA Mix 4 Stereo, the expanders are processed after each channel has already been sent to the VCA channel output. Again, the Offset expander is an exception.
The order of operations generally proceeds from left to right. The order typically does not affect the end result unless Aux Send modules are used. However, some expanders have restrictions on where they are placed, and/or how many can be used for a single mix module. Refer to each expander for details.
CV inputs and outputs are generally all monophonic, with the effect applied equally to all polyphonic channels in the main mix module. The two exceptions are the Aux Send module and Mix Pan module, both of which fully support polyphonic cables. Extra poly channels beyond what is seen in the parent module are ignored.
Venom expanders are written so that communication between the parent module and the expander does not add any sample delays.
Some of the expanders have hidden options that are only available in the main mix module context menu. These expander related menu options only appear when the relevant expander is connected to the mix module.
- If enabled (default), then mute/solo transitions are slewed to take 25 msec (or more if fades are applied).
- If disabled, then mute/solo transitions are immediate (unless fades are applied)
- If disabled (default), then Mute CV and Solo CV function as a gate
- If enabled, then Mute CV and Solo CV function as a toggle
Controls how left and right channels are attenuated/amplified as a mono input is panned. This affects the perceived loudness as a signal is panned left and right versus center.
- 0 dB (linear: center overpowered)
While panning left, the left gain is held constant while the right is attenuated. While panning right, the right gain is held constant while the left is attenuated. Mono signals sound softer when panned left or right compared to when panned center. - +1.5 dB side (compromise: center overpowered)
When panning left, the left channel is amplified slightly to +1.5 dB when panned full left. Likewise when panning right the right channel is amplified slightly. Mono signals still sound softer when panned left or right, but to a lesser degree. - +3 dB side (default - equal power)
While panning left, the left channel is amplified until it reaches +3 dB when panned full left. The right channel is similarly amplified when panning right. Mono signal loudness is perceived to be constant regardless whether panned left, center, or right. - +4.5 dB side (compromise: side overpowered)
When panning left, the left channel is amplified until it reaches +4.5 dB when panned hard left. The right channel is similarly amplified when panning right. Mono signals sound slightly louder when panned left or right compared to center. - +6 dB side (linear: side overpowered)
When panning left or right, one side is amplifed and the other attenuated in equal amounts, such that the net gain is always 1. Mono signals sound louder when panned left or right compared to center. - -1.5 dB center (compromise: center overpowered)
Same as +1.5 dB side except the center is attenuated rather than amplify the side. - -3 dB center (equeal power)
Same as +3 dB side except the center is attenuated rather than amplify the side. - -4.5 dB center (compromise: side overpowered)
Same as +4.5 dB side except the center is attenuated rather than amplify the side. - -6 dB center (linear: side overpowered)
Same as +6 dB side except the center is attenuated rather than amplify the side.
Controls how left and right channels are attenuated/amplified as a stereo input is panned. All of the mono options are available, plus the following
- True panning (transfer content)
Right channel input is mixed in with the left channel while panning left, and vice versa while panning right. - Follow mono law (default)
The mono pan law setting is used for stereo inputs as well
Gives the ability to add constant offset voltages immediately before and/or after a level gain is applied on the main mixer. Offsets are always the first expander to be applied, and so the Offset expander must be adjacent to the main mix module.
Offsets are available for the individual numbered input channels, as well as the final mix output.
The Pre offsets are applied immediately before each level gain.
The Post offsets are applied immediately after each level gain.
Unlike other expanders, offsets are included in VCA channel outputs when used with VCA Mix or VCA Mix Stereo.
Offsets are often used for converting unipolar signals to bipolar, or vice-versa.
Only one Offset expander can be used per mix module.
Provides buttons and CV inputs to mute any of the four numbered channels, as well as the final mix. The channel is muted whenever the button is glowing bright red.
The CV inputs function as Schmitt triggers, switching to high when the voltage rises to 1 volt or more, and switching to low when dropping to 0.1 volt or less.
A context menu on the main Mix module determines whether the CV inputs function as gates or triggers. By default the CV functions as a gate, meaning the mute is turned on when the CV goes high, and turns off when the CV goes low. If configured as a trigger, then the mute state toggles on or off each time the CV transitions to high.
Manual button presses can override the CV inputs - every button press is guaranteed to toggle the mute state.
Mute states can be overriden by Solo expander buttons.
Since Solo and Mute are applied at the same time, they must be adjacent if both expanders are used. It does not matter which appears first.
Only one Mute expander can be used per mix module.
Provides buttons and CV inputs to solo one or more of the numbered mix channels. If none of the solo buttons are lit, then the expander has no effect. If at least one solo button is lit (bright green), then all channels that are not lit are muted. Numbered channels on a Mute expander are ignored if at least one solo button is lit.
The CV inputs function as Schmitt triggers, switching to high when the voltage rises to 1 volt or more, and switching to low when dropping to 0.1 volt or less.
A context menu on the main Mix module determines whether the CV inputs function as gates or triggers. By default the CV functions as a gate, meaning the solo is turned on when the CV goes high, and turns off when the CV goes low. If configured as a trigger, then the solo state toggles on or off each time the CV transitions to high.
Manual button presses can override the CV inputs - every button press is guaranteed to toggle the solo state.
Since Solo and Mute are applied at the same time, they must be adjacent if both expanders are used. It does not matter which appears first.
Only one Solo expander can be used per mix module.
Converts mute/unmute transitions from Mute and Solo expanders to timed fade transitions.
A single Time control for each numbered Mix channel controls the fade in (rise) time and the fade out (fall) time. The fade time ranges from 0 to 30 seconds.
Each channel also has a Shape control, with full counterclockwise (-100%) representing exponential, center (0) representing linear, and full clockwise (100%) representing logarithmic. Points in between are a proportional blend of linear and logorithmic/exponential.
The fade level outputs provide CV representing the current fade level of each channel. The output is 0 V when fully muted, and 10 V when fully unmuted.
Fade is actually an expander for the Mute and Solo expanders, and thus must appear adjacent and to the right of either a Mute or Solo expander.
Only one Fade expander can be used per mix module. Fade and Fade 2 are mutually exclusive. Using Fade precludes the use of Fade 2.
Fade 2 is identical to Fade except it gives independent control over the fade rise and fall times.
Each Time control from Fade is replaced by a pair of Rise and Fall controls on Fade 2.
Only one Fade 2 expander can be used per mix module. Fade 2 and Fade are mutually exclusive. Using Fade 2 precludes the use of Fade.
Allows panning of Mix input channels left and right via numbered knobs and inputs.
Each knob ranges from -1 (full counterclockwise) for hard left, to 0 (noon) for center, to +1 (full clockwise) for hard right.
Each CV input has an associated CV attenuverter. The CV is added to the knob value to determine the final pan level. Bipolar CV is expected, with -5V representing hard left and +5V representing hard right (assuming the knob is center panned). So -10V is guaranteed to result in pan hard left even if the knob is panned hard right. Similarly, +10V guarantees pan hard right even if the knob is panned hard left.
The CV inputs support polyphonic cables.
Pan is only available to stereo mix modules Mix 4 Stereo and VCA Mix 4 Stereo. Only one Pan module can be used per mix module.
Provides an auxilliary mix of the four mix inputs that can be sent to the Send output(s), and optionally returned to the Return input(s)
Each numbered knob can attenuate the channel to between 0% and 100%, before the channels are mixed and sent to the Send output(s).
The Return input(s) are attenuated by the Return knob before being mixed in with the final Mix module mix. The return is mixed in prior to applying the final Level gain at the main Mix module.
Both Send oututs and Return inputs support polyphonic cables.
The Mute button sets the Send output(s) to constant 0V when lit.
Both Left and Right Send and Return inputs and outputs are used when the main Mix module is stereo (Mix 4 Stereo, or VCA Mix 4 Stereo).
If the main Mix module is not stereo (Mix 4, or VCA Mix 4), then the Right Send output is constant monophonic 0V, and any right Return is ignored.
The position of the Send module in a chain of Mix expanders is important. Expanders to the left of the Send expander affect the Send output. Expanders to the right of the Send expander do not affect the Send output.
At most 16 Send modules can be used with a single mix module. The maximum is fewer than 16 if other expander types are used in addition to the Send modules.
The Return inputs have a Chain button that changes the behavior of the expander for use with chained mixers. If enabled, then the Return knob is disabled, and the Left Return and Right Return inputs receive the chained Send from a prior Aux Send expander. For example, suppose you have three VCA Mix 4 Stereo modules chained together named Mix1, Mix2, and Mix3, and each has an Aux Send module, named Send1, Send2, and Send3. Leave the chain option off on Send1, and enable chain on Send2 and Send3. Patch the Send1 Send outputs to Send2 Return (Chain) inputs, and Send2 Send outputs to Send3 Return (Chain) inputs. Finally patch the Send3 Send outputs to the effect module inputs, and the effect outputs to the Send1 Return inputs. The Send1 Return knob controls the return level, and the Send3 Mute button can be used to mute the entire send chain.
Use your mouse as a controller, without having to point at any specific module. Activate the Mouse Pad output by pressing and holding some combination of Shift, Ctrl, and/or Alt (Option on Mac). A 10V gate is generated while active, and there are two indpendent CV outputs that track the mouse movement. The horizontal axis controls the X output, and vertical the Y.
The top four buttons configure how the Mouse Pad is activated. At least one of Shift, Ctrl, and/or Alt must be enabled to use Mouse Pad. Whichever buttons are activated, that specifies what key combination is required to track movement and produce output. The Mouse Pad stops tracking motion when at least one of the keys is released.
The Tog (toggle) button changes behavior. The first combination press activates, and it remains active after release. The next combination press deactivates tracking.
Both X and Y have 4 controls to configure the output.
The Scale knobs amplify, attenuate and/or invert the mouse sensitivity. At 100% both the X and Y have a 10V range.
The Origin knobs determine what part of the VCV Rack window corresponds to 0V for X and Y. Values of 0%, 0% correspond to the lower left corner of the window. Values of 100%, 100% correspond to the the upper right corner. So a value of 50%, 50% corresponds to the center of the window.
The Absolute buttons control whether the output is absolute, or relative to the mouse position at the moment of activation.
The Return buttons control whether the outputs return to 0 upon release of the activation keys, or if the last value is held until the next activation.
All outputs are monophonic.
Gate is high (10V) whenever the mouse is tracking, and low (0V) when not tracking.
X output follows the horizontal motion of the mouse, and Y the vertical motion. Both values have a 10V range when Scale is at 100%
Multiple Mouse Pads can be effectively used if each is given a different combination of activation keys. This allows you to use a single mouse to send user controlled CV to different parts of your patch on demand.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are monophonic 0V if Mouse Pad is bypassed.
Merge one or more sets of mono and/or poly inputs into polyphonic outputs.
This merge utility is extremely flexible, with many configurations possible. It can merge a set of monophonic inputs into one polyphonic output. It can also merge a set of polyphonic inputs into one polyphonic ouput. Or it can merge a mixture of mono and poly inputs into one polyphonic output. Finally, there can be multiple sets of merges, each with its own poly output.
The thick red lines indicate which input ports are merged and sent to which output port. The groupings are defined by which output ports are patched. Unpatched output ports are ignored. The module is automatically reconfigured each time you patch or unpatch an output port. Each patched output merges the inputs from that row and above until it reaches another row with a patched output. If there are no output ports, then the module assumes the last output port will be patched.
The number of polyphonic output channels cannot exceed 16. If the sum of polyphony counts across the inputs exceeds 16, then excess channels are dropped, and the LEDs next to input ports with dropped channels glow red.
Each input port has a context menu to explicitly set the number of input channels, regardless how many are actually there. In addition there is a module context menu option to set the input channel count for all inputs. By default each input port channel count is set to Auto. The hover tooltip for each input port includes information on the current channel configuration. Mono inputs are replicated to match the specified input channel count. If the specified count is greater than the actual number of input channels, then extra channels are assigned constant 0V. If the specified count is less than the actual input channel count, then the dropped channels LED for that port glows red.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are monophonic 0V if Multi Merge is bypassed.
Split one or more poly inputs into multiple mono or poly outputs.
This split utility is extremely flexible, with many configurations possible. Each polyphonic input can be split into any combination of monophonic and polyphonic outputs. The module has default Automatic behavior for distributing the input channels to the outputs. But the default behavior can be overridden by defining a specific channel count for one or more output ports via output port context menus. The hover tooltip for each output port includes information on the current channel configuration.
The thick red lines indicate which input port is split to which set of output ports. The groupings are defined by which input ports are patched. Unpatched input ports are ignored. The module is automatically reconfigured each time you patch or unpatch an input port. Each patched input distributes its channels to the same output row downward until it reaches another row with a patched input. If no input is patched, then the module treats it as if a monophonic 0V input is patched to the top input.
Multi Split attempts to distribute the input channels evenly to the output ports. When the input channels cannot be divided evenly, higher (lower numbered) output ports take precedence over lower (higher numbered) ports. However, any output channel that is configured for a specific channel count will always output that number of channels. So if you subtract the sum of the fixed output counts from the input count, then the remainder are divided amongst the output ports that are configured for Auto assignment. If the distributor runs out of input channels, then constant 0V is used for the remainder of the output channels.
If the input channels cannot fit within the output channels, then the LED next to the input port glows red. This can only happen if all output ports in the group are configured for a specific channel count, and the sum of the channel counts is less than the input channel count.
This all probably sounds confusing. But once you start patching, it will probably start making sense quickly. Even if you cannot figure out the automatic distrubution algorithm, you can always take control by assigning a specific channel count to each output port.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are monophonic 0V if Multi Split is bypassed.
Quantizer for any scale with up to 13 intervals between notes. The scale is defined by a root note for the scale, followed by a series of intervals. The first interval is added to the root to get the 2nd note in the scale. The second interval is added to the 2nd note to define the 3rd note, etc. The final interval defines the step from the Nth note of the scale to the root of the next pseudo-octave in the series. The total interval from one root to the next need not be an octave.
The module is also convenient for defining extended chords based on intervals.
This switch controls what unit is used to display and or manually enter intervals.
- V/Oct: 1 V = 1 octave.
- Cents (default): 100 cents = one 12 Equal Tempered half step, and 1200 cents = one octave. The scale and/or interval need not have any relationship to 12 ET - the cents unit is just a convenient way to measure an interval.
- Ratio: Interval frequency ratios are unitless, and are defined as the frequency of the high note / frequency of the low note. For example, a perfect fifth may be entered as 3/2, but the ratio will always be displayed relative to 1. So a perfect fifth would be displayed as 1.5:1
Controls how intra-note intervals are defined.
If On (default), then intra-note intervals are specified as an integral number of chromatic steps that are defined by an equal division (EDPO) of some larger interval (Pseud-Oct Interval).
If the Equal Divs button is off, then the Pseud-Oct Interval and EDPO values are ignored, and intra-note intervals are specified directly as an interval.
Defines the pseudo-octave interval that will be divided into equal divisions to define the chromatic interval for the scale. The default knob value is one octave. The interval unit is specified by the Interval Unit switch.
The monophonic input always uses the V/Oct standard, regardless how the Interval Unit switch is configured.
The effective pseudo-octave interval is the sum of the knob and input values, clamped to a value between 0 and 4 octaves. The effective value is displayed below the knob, using the units defined by the switch.
The PseudoOctave Interval is ignored and nothing is displayed if the Equal Divs button is off.
Defines the number of equal divisions of the pseudo-octave interval, which in turn defines the scale's chromatic step interval. The default value is 12.
The monophonic input is scaled at 10 divisions per volt.
The effective number of divisions is the sum of the knob and input values, rounded and clamped to an integral value between 1 and 100. The effective value is displayed below the knob.
The EDPO is ignored if the Equal Divs button is off.
Defines the number of intervals or steps in the repeating scale (notes - 1). The final interval defines the jump from the Nth note in the scale to the root of the next pseudo-octave. The default value is 12.
The monophonic input is scaled at 0.5 Volt per step.
The effective scale length is the sum of the knob and input values, rounded and clamped to an integral value between 1 and 13. The effective value is displayed below the knob.
Defines the root note of the repeating scale.
The switch beside the knob defines what unit is used for display and manual entry.
- V/Oct: 1 V = 1 octave, where 0 V represents the note C4
- Cents: 100 cents = one 12 ET half step, where 0 cents represents the note C4
- Freq (default): Measures the root note frequency in Hz.
The knob default is always C4, regardless which unit is used.
The monophonic input always uses the V/Oct standard.
The effective Scale Root is the sum of the knob and input values, clamped to a value between -4V (C0) and 4V (C8). The effective value is displayed below the knob, using the units defined by the switch.
Determines how input voltages are quantized
- Up: Input values between two notes are always rounded up to the higher note
- Nearest (default): Input values between two notes are always rounded to the closest note, with values at the halfway point rounded up
- Down: Input values between two notes are always rounded down to the lower note
If enabled, then the notes of the scale are mapped to even divisions of the total scale interval, such that each note of the scale has equal probability when the input is fed random values.
By default this mode is off.
The 13 small knobs and monophonic inputs below the display area define the intervals used in the scale. Up to 13 channels in the Poly Interval input can also be used to modulate the 13 intervals.
The method used to define the interval depends on the Equal Divs button.
Each interval is defined as an integral number of chromatic steps as defined by the Pseudo-Octave Interval and the EDPO. The left most knob defines the interval between the root note and the 2nd note of the scale. The right-most active knob defines the interval between the Nth note of the scale and the root of the next pseudo-octave.
Each knob defaults to 1, with a range of 1 to 100.
The monophonic inputs are scaled at 10 chromatic steps per volt.
The effective count is the sum of the knob and input values, rounded and clamped to an integral value between 1 and 100. The effective count is displayed above the respective knob. Inactive interval knobs, as defined by the Scale Length, do not have any value displayed above them.
Each interval is specified directly.
The knob value defaults to 0 (no change in pitch), with a range from 0 to 2 octaves. The unit used for manual entry and display is controled by the Interval Unit switch.
The monophonic input is scaled at 1 volt per octave.
The effective interval is the sum of the knob and the input values, clamped to a value between 0 and 2 octaves. The effective interval value is displayed above each respective knob. Inactive interval knobs, as defined by the Scale Length, do not have any value displayed above them.
The display panel is divided into 3 sections. As already described above, the top section displays the effective values for the upper controls, and the bottom section displays the effective values for the 13 interval controls.
The middle section indicates which note within the scale is selected. Each polyphonic channel has its own position within a 4 x 4 grid above each interval.
The left most grid above the left most interval knob represents the root of the scale. The next grid represents the 2nd note, etc.
The indicator is yellow when the selected note is >= the effective Scale Root, and red if < the Scale Root. The character within each indicator represents the distance away from the root (pseudo)octave. A value of 0 represents the scale containing the Scale Root. The (pseudo)octave indicators are coded as follows:
- 0-9 = 0-9
- A-Z = 10 - 35
- a-z = 36 - 61
- <space\62 or higher
The polyphonic IN input provides the V/Oct frequency control voltage to be quantized.
If the polyphonic Trig input is patched, then input values are only quantized when a trigger is received. Each quantized value is held until the next trigger is received.
If the Trig input is not patched, then input V/Oct values are continuously quantized.
Equal Division Chromatic scales with more than 13 intervals may be accomplished by setting the Scale Length to 1 and the first (and only) interval to 1.
The polyphonic OUT output produces the quantized V/Oct values.
This polyphonic output produces integral voltages that represent the pseudo-octave of each quantized note. A value of 0 represents the scale pseudo-octave containing the effective Scale Root. A value of 1 represents the next scale pseudo-octave up. A value of -1 represents the first pseudo-octave below the effective Scale Root. And so on...
This value will not have much meaning if using a chromatic scale with Scale Length = 1.
If the Trig input is not patched, then a 1ms 10V trigger is issued every time a new note is quantized.
If the Trig input is patched, then the Trig input is passed through directly to the Trig output.
The polyphony channel count for the three outputs above are computed as the maximum number of channels found between the IN and Trig inputs.
If one input is monophonic, and the other polyphonic, then the monophonic values are replicated to match the channel count of the polyphonic input.
If both inputs are polyphonic, but one input has fewer channels than the other, then missing channels are treated as constant 0V.
This polyphonic output produces all the V/Oct values for the scale starting at the Scale Root, through the first note of the next scale one scale pseudo-octave up. The number of channels will be the Scale Length + 1.
This output can also be used as an extended chord rooted at the Scale Root. Simply define the intervals between the notes in your chord, patch the root of the chord to the Scale Root input, and leave the IN input unpatched.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If the module is bypassed then the Trig input is passed unchanged to the Trig output. All other bypassed outputs are monophonic constant 0 volts.
Converts up to 14 channels of a polyphonic "chord" input into a set of CV outputs that define a scale for the Non-Octave-Repeating Scale Intervallic Quantizer (NORSIQ).
Polyphonic V/Oct channels at the CHORD input are sorted, and the lowest note defines the scale root, the number of channels determines the scale length, and the intervals between the sorted notes define the intervals for the NORSIQ. The computation of the defining scale CV may be continuous, or it may be held constant until a trigger is received.
The NORSIQ module must be configured properly for the CV from the NORSIQ Chord To Scale module to define the correct scale:
- The EQUAL DIVS button must be off so that intervals can be defined directly.
- All 14 Interval knobs must be fully counter-clockwise (0V, 0 cents, or 1:1 ratio)
- The SCALE LENGTH knob must be fully counter-clockwise (1)
- The SCALE ROOT should be at the default noon position (C4), unless you want to transpose the scale to a different key.
The PSEUD-OCT INTERVAL and EDPO knobs and inputs are ignored. The INTERVAL UNIT, ROOT UNIT, ROUND, and EQUI LIKELY contols may configured as you see fit.
The NORSIQ has a "NORSIQ Chord To Scale configuration" factory preset that quickly sets the appropriate configuration with some parameters locked to make sure it works properly.
Controls where the scale repeats
- Off (gray - default): The last (highest) note of the sorted chord input defines the last note of the scale, which becomes the root of the next scale.
- On (white): An extra note that is an octave multiple above the scale root is added to define the last note of the scale. The lowest root octave that is above the highest chord note is used. If the highest chord note is already an octave of the root, then it becomes the last note of the scale, and no note is added.
If patched, then the outputs will not change until a monophonic trigger is received. The trigger is detected by a Schmitt trigger with a high threshold of 2V and low threshold of 0.1V.
If left unpatched, then the outputs are continuosly updated according to the current inputs.
The polyphonic V/Oct input used to define the scale. If the OCTAVE FOLD is off, then only the first 14 channels are used. If the OCTAVE FOLD is on, then only the first 13 channels are used.
The result of the TRIG input Schmitt trigger is forwarded to the TRIG output so that the trigger remains in sync with any scale changes.
This monophonic output is typically patched to the NORSIQ SCALE ROOT input to define the root of the scale according to the lowest sorted note from the CHORD input. The ROOT output can be ignored if you want to transpose the scale to a different key.
This monophonic output must be patched to the NORSIQ SCALE LENGTH input to define the length of the scale.
This polyphonic output must be patched to the NORSIQ POLY INTERVALS input to define the interval between each of the notes in the scale.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are constant monophonic 0V if NORSIQ Chord To Scale is bypassed.
A single input is panned across eight outputs in three dimensional space. The output ports are placed at the vertices of a virtual cube. X, Y, and Z panner controls indepently pan the input between outputs on opposite faces of the cube. The panners function linearly in amplitude, ranging from 0% to 100%. The three orthogonal panners are multiplicative. When all three controls are at an extreme, 100% of the input is panned to a single output. When all three controls are at 50%, then each output receives 12.5% of the input. A final Level control can further attenuate the final outputs.
Every input and output is fully polyphonic. The output channel count is the maximum channel count found across all inputs. Monophonic inputs are replicated to match the final output channel count. Polyphonic inputs with fewer channels use constant 0V for any missing channels.
The faceplate has a perspective view of a cube with an output at each of the eight vertices. The outputs are not individually labeled on the faceplate, but when you hover over an output a name is displayed that identifies whether the output is left or right, bottom or top, and front or back.
X controls the left to right ratio, and is measured as percent right.
Y controls the bottom to top ratio, and is measured as percent top.
Z controls the front to back ratio, and is measured as percent back.
Each panner control ranges from 0% to 100%, with the default 50% at noon.
Each dimension has a bipolar CV input and dedicated attenuator. The CV is scaled at 10% per volt by default. The CV is summed with the control value and clamped to a value between 0% and 100%. With a dimension at 50% and the CV attenuator at 100%, a +/- 5V bipolar can modulate a dimension from one extreme to the other.
A module context menu option is available to scale the CV at +/- 200% instead of +/- 100%. This enables a simple bipolar +/- 5V sine or triangle modulator to transition to one extreme and hold, before transitioning in the other direction.
If you prefer to work with spherical coordinates, then the Sphere To XYZ module is available to convert r, theta, phi spherical coordinates into X, Y, Z cartesian coordinates.
By default, polyphonic channels are preserved at the outputs. If the Mono Output button is enabled, then polyphonic output channels are summed to a monophonic output signal.
The final output levels can be attenuated with the Level control. Each output is attenuated the same amount. This control may be especially useful when working with polyphonic outputs that are summed to a mono output.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are constant monophonic 0V if Pan 3D is bypassed.
Poly Clone replicates each channel from a polyphonic input and merges the result into a single polyphonic output. It is especially useful with the Recurse modules when using polyphonic inputs. Poly Clone provides a convenient way to replicate channels in polyphonnic CV inputs to match the recursion count.
Up to four auxilliary poly inputs may also be cloned via the Auxilliary Clone Expander.
Selects the number of times to clone or replicate each input channel. Possible values range from 1 to 16.
Each channel from the polyphonic input is replicated based on the Clone count as long as the total replicated channel count does not exceed 16. Channels that cannot be replicated the full amount are ignored.
No input is treated as monophonic constant 0V.
For each channel appearing at the input, the corresponding LED above glows yellow if the channel could be successfully replicated, and red if it could not be replicated. LEDs beyond the input channel count remain off (black).
The GRP button controls how the cloned channels will be grouped at the output
- Input channel (yellow, default) - All the cloned channels for a given input channel will be grouped together at the output.
- Input set (blue) - The input channels will be grouped together in order as a set, and then the set will be cloned at the output.
All of the replicated channels are merged into the single polyphonic output. The order of the channels is dependent on the GRP button.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If Poly Clone is bypassed then the output is constant monophonic 0 volts.
Crossfade between channels of a polyphonic signal.
A unipolar phasor from 0 to 10V drives the crossfade between the channels of a polyphonic input. The phasor can be the internal LFO, an external Phasor input, or the sum of both. The current phasor voltage determines which channel(s) are playing at that moment. An envelope controls how each channel fades in and out. For an input with N channels, the 10V phasor range is divided into N equal voltage ranges, one for each channel. That range represents 1 width unit. The width of the channel envelopes can vary, and is expressed in the channel width units. An envelope width of 1 means that the channel envelopes abut each other, but never overlap. Widths greater than 1 result in channel envelopes overlapping each other. Widths less than 1 result in gaps between channel envelopes. The shape of the channel envelopes is controlled by Hold, Skew, Rise shape, and Fall shape controls. There are outputs for the net phasor, the polyphonic channel gates, the polyphonic channel envelopes, the polyphonic final output, and the monophonic mix of final outputs. Level control and a VCA can be used to adjust the output volume and/or to apply amplitude modulation effects.
Poly Fade can run with slow LFO rates, or high audio rates, but there is no anti-aliasing applied.
For each parameter in this section there are two knobs and one monophonic input. The left knob sets the base level, the input provides for CV modulation, and the right knob attenuates and/or inverts the CV. The attenuated CV is always added to the base knob value to establish the final value for the parameter.
Note that this section is labeled assuming that the phasor is going in a forward (ascending channel) direction. When phasing in reverse, the rise is actually the fall, and vice versa.
Establishes the overall width of each channel's envelope, expressed as the number of channel slots to occupy. A value of 1 results in continuous sound, but without any overlap of channels. Less than 1 results in moments of silence between channels. Values greater than 1 result in channels overlapping. If the value matches the number of input channels, then each channel will play throughout the entire phasor cycle, but each channel envelope will still have a different phase.
The CV is scaled to 1 channel slot per 0.5V.
The net sum is clamped to a value between 0.0625 to 16. If the value exceeds the number of channels then it is internally truncated to match the channel count.
The default value is 2.
Specifies what percentage of the channel envelope is held at full volume, expressed as a percent.
A value of 100% yields a square wave, regardless what the Skew, Rise, and Fall values are. A value of 0% yields something between a saw and a symmetric triangle. Intermediate values yield some form of trapezoid.
The CV is scaled at 10% per volt.
The net sum is clamped to a value between 0% and 100%.
The default value is 0%.
Specifies what percentage of the remaining envelope width is dedicated to the rise, with the remainder going to the fall. If the Hold value is 0%, then a 50% skew yields a symmetric triangle with equal rise and fall ramps.
A value of 0% yields a saw wave ramp down with an immediate rise, and a sloped fall.
A value of 100% yields a saw wave ramp up with a sloped rise, and immediate fall.
Again, the concept of rise and fall assumes the phasor is moving in a forward direction.
The CV is scaled at 10% per volt.
The net sum is clamped to a value between 0% and 100%.
The default value is 50%.
Specifies the amount of curve applied to the rise and fall ramps using J curves. The values range between -100% and 100%, with 0% being linear. Negative values are similar to exponential, and positive logarithmic, though the math is different.
Both CV inputs are scaled at 10% per volt.
The net sums are clamped to a value between -100% and 100%
The default values are 0% (linear).
Specifies the maximum level of the channel and sum outputs, with value ranging from 0% to 100%.
The CV is scaled at 10% per volt.
The net sum is clamped to a value between 0% and 100%.
The default value is 100%.
The top row of dimly lit small green LEDs indicate which input channels are used. The bright green indicates the starting channel(phase 0). Off LEDs indicate excluded channels.
The bottom row of larger yellow LEDs indicate which channels are currently producing output, with the intensity proportional to the current level of the envelope.
Controls the frequency of the internal LFO phasor. The knob ranges from 0.0079842 Hz to 32.703 Hz (C1). The default is 2.044 Hz.
Note that the ping pong (triangle LFO) rate is actually half the displayed frequency so as to maintain a constant rate of channel switching relative to forward and backward modes.
The 1V/Oct CV input can drive the rate both lower and higher. The minimum rate is 0.0015 Hz (11.1 minutes per cycle). The maximum rate is 12 kHz, however there is no anti-aliasing. So mid to high audio rates can lead to harsh results with lots of aliasing.
Controls the shape of the internal phasor, and thus the direction of the fade.
Patched CV input actually sets the value of the button, so any CV is effectively disabled if the button is locked.
There are four possible values
- Forward (right arrow, default) = a rising ramp saw wave = 0V CV
- Backward (left arrow) = a falling ramp saw wave = 1V CV
- Ping Pong (bidirectional arrow) = a triangle wave = 2V CV
- Off (dashed line) = disables (freezes) the internal phasor = 3V CV
CV values are rounded to the closest valid value.
If the direction is Off then by default the internal phasor is reset to 0. The module has a context menu option to disable the "Reset if direction off" so that you can freeze the internal phasor at its current position and then later pick up where you left off.
Controls how many of the polyphonic channels participate in the fade. The value can range from 0 to 16.
A value of 0 represents Automatic, meaning all channels appearing at the In input are used.
If the set value is less than the number of input channels, then the unused channels are ignored.
If the set value exceeds the number of input channels, then the missing channels default to constant 0V.
Patched CV input actually sets the value of the knob, so any CV is effectively disabled if the knob is locked.
CV is scaled at 0.5V per channel, and values are rounded to the nearest valid multiple of 0.5.
Controls which input channel represents phase 0. It can be any value between 1 and 16.
Patched CV input actually set the value of the knob, so any CV is effectively disabled if the knob is locked.
CV is scaled at 0.5V per channel, with 0.5 representing 1. Values are rounded to the nearest valid multiple of 0.5.
The phasor input is summed with the internal LFO phasor to establish the effective phasor that controls the fade. Bipolar signals can be used. A value of 0 represents phase 0, and the phase increases linearly as the voltage increases until a value of 10V loops back to phase 0. The phase is cyclical, so values above 10V or below 0V effectively wrap around.
A small color coded button below and to the right of the Phasor input controls slew that can be applied to the phasor input before it is summed with the internal LFO. Slew can be helpful for reducing audio pops created by sudden changes within the incoming phasor signal.
- Off (gray - default)
- 3 msec/V (yellow)
- 6 msec/V (orange)
- 10 msec/V (purple)
The rising edge of a trigger at this input instantly resets the internal LFO phasor back to phase 0.
This input represents the polyphonic channels that are crossfaded.
This is the sum of the polyphonic crossfaded channel outputs.
This is the effective phasor - the sum (unity mix) of the internal LFO phasor and the phasor input. This is guaranteed to have a unipolar output between 0V and 10V.
This port outputs a high 10V gate for each channel that currently has a non-zero envelope.
This port outputs the envelope for each of the channels.
This port outputs the crossfaded outputs for each of the channels.
The effective number of input channels is the greatest of the following values:
- The number of poly channels at the input
- The selected number of crossfaded channels
- The selected start channel.
If the actual input is monophonic, then the input is replicated to match the effective input channel count.
If the actual input is polyphonic with fewer channels than the effective input channel count, then missing channels are assigned constant 0V.
By default the number of output channels is minimized to match the selected number of crossfaded channels. In this case the start channel is always assigned to output channel 1, and there are no unused channels in the output.
A module context menu option is available to disable the output channel minimization. In this case the effective input channels map directly to the output channels. Unused input channels become constant 0V in the output.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are monophonic 0 volts when Poly Fade is bypassed.
Provides an offset control for each channel of a polyphonic signal. For each polyphonic output channel, the channel's knob voltage is added to the input voltage to get the final output voltage.
There is one offset knob for each of the possible polyphonic channels. The default (initialize) value for all knobs always starts out at 0 volts. Of course the default can be overriden by the standard Venom parameter context menu option.
The module context menu has the following options to configure the behavior of the knobs:
Determines the minimum and maximum voltage of the knobs.
- 0-1 V
- 0-2 V
- 0-5 V
- 0-10 V
- +/- 1 V
- +/- 2 V
- +/- 5 V
- +/- 10 V (default)
- Custom
If Custom is chosen, then two menu options are added to set the custom range: Custom min for the full counter-clockwise level, and Custom max for the full clockwise level. The min and max values can range from -100 to 100. You can enter simple mathematical expressions - all of the keyins that work for setting a knob value also work for the custom levels. You are free to set the min greater than the max so the knobs work in reverse.
Determines how values are quantized.
- Off (continuous) (default) - Neither the output nor the knob offset values are quantized.
- Output to Integers (octaves) - The sum of input voltage plus knob value is quantized to the nearest integral Volt.
- Output to 1/12 V (semitones) - The sum of input voltage plus knob value is quantized to the nearest 1/12 Volt.
- Output to custom interval - The sum of input voltage plus knob value is quantized to the nearest multiple of an interval that you specify.
- Offset to Integers (octaves) - The knob offset value (and display value) is quantized to the nearest integral Volt.
- Offset to 1/12 V (semitones) - The knob offset value (and display value) is quantized to the nearest 1/12 Volt.
- Offset to custom interval - The knob offset value (and display value) is quantized to the nearest multiple of an interval that you specify.
If either custom interval option is chosen, then a Custom quantize interval menu option is added to set the custom interval. The interval can be any positive value up to 100. You can enter simple mathematical expressions - all of the keyins that work for setting a knob value also work for the custom interval. If you enter a value less than or equal to zero, then the value will be transformed into 1.
Determines how knob values are displayed and entered in knob context menu and hover text. Output values are always in Volts.
- Volts (V) (default)
- Cents (¢)
By default the number of output channels matches the number of input channels. Knobs for channels above the output count are ignored.
There is a "Polyphony channels" option in the module context menu that lets you override the default and select a specific output channel count. Input channels and knobs above the specified channel count are ignored. Monophonic inputs are cloned to match the selected channel count. If the input channel count is poly but less than the selected channel count, then missing channel inputs are assumed to be constant 0 volts, meaning the knob alone specifies the output voltage.
The number of polyphonic channels at the output is displayed in the LED panel. The display will be yellow if the number of output channels is greater than or equal to the input channel count. The display will be red if the selected channel count is less than the input channel count.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If Poly Offset is bypassed then the input is passed unchanged to the output.
Ten row polyphonic sample and hold combined with a shift register, with oversampling options.
Each row has its own polyphonic Trigger and Data inputs, and a polyphonic Hold output. In total that is 10 independent polyphonic sample and hold circuits. However, the inputs are normaled in a way that enables consecutive rows to function as a shift register.
If no input is provided, then values are sampled from an internal random number generator.
Manually triggers the first row only
This color coded button controls how much oversampling is applied to minimize aliasing when triggering the sample & hold at audio rates. Oversampling is CPU expensive, so should only be applied when needed.
- Off (gray - default)
- 2x (yellow)
- 4x (green)
- 8x (light blue)
- 16x (dark blue)
- 32x (purple)
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
This color coded button controls the output range of the internal random number generator
- 0-1 V (yellow)
- 0-5 V (green)
- 0-10 V (dark blue - default)
- +/- 1 V (pink)
- +/- 5 V (orange)
- +/- 10 V (purple)
Resets all polyphonic channels of all 10 Hold outputs to 0 V.
Each row functions as an independent sample and hold circuit.
The rising edge of a trigger input causes the row to sample and hold the current value at the Data input. The trigger is a Schmitt trigger that goes high above 2V and goes low below 0.1 V.
The Trig input is polyphonic - each polyphonic channel can be triggered independently.
For the first row only the sample can be triggered by the Trig input or the Trig button.
All TRIG inputs from the 2nd row onward are normaled to the TRIG input from the row above. So a trigger at row one can trigger all rows if none of the other rows are patched.
This is the source that is sampled.
If the Trig input for the row is patched, then the Data input is normaled to the internal random number generator. Every row gets its own random value. Also each polyphonic channel gets its own random value.
If the Trig input is not patched, then the Data input is normaled to the Hold output from the row above. This is what enables the module to function as a shift register.
This output holds the last value that was sampled. Normally the value remains constant until the next trigger. However, when oversampling is enabled the value will wobble a bit for a few samples before stabilizing.
The number of polyphonic channels that are sampled and held at the output depends on the number of polyphonic channels found at the row inputs. The output polyphony count is the maximum count found between the Trig and Data inputs.
If you are using oversampling and you do not require the Trigger button, then consider patching from the bottom and work your way up. For example, if you only need a 4 step shift register, then patch the trigger and data signals to the 7th row. If you patch the top row, then all 10 rows are triggered, and the module needs to do more work and consumes more CPU. The CPU usage can be dramatically different when oversampling is involved.
If the Trig input is monophonic, and the Data input is polyphonic, then all Data channels will be sampled simultaneously upon receipt of a trigger.
If the Trig input is polyphonic, and the Data input is monophonic, then each channel will sample the input when the channel receives a trigger. If normaled to the random number generator, then each channel will receive its own random value.
If both Trig and Input are polyphonic with the same number of channels, then each channel trigger will sample the appropriate data channel.
If both are polyphonic but the Data has fewer channels, then the missing data channels will be treated as constant 0 V.
If both are polyphonic but the Trig input has fewer channels, then the extra channels at the Data will never be sampled.
By default all held values are stored with the patch and restored upon patch load. This feature can be disabled via the "Save held values" module context menu option.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If Poly S&H ASR is bypassed then all outputs are monophonic constant 0 V.
Provides a level control for each channel of a polyphonic signal. For each polyphonic output channel, the channel's input voltage is scaled (attenuated and/or iniverted and/or amplified) based on the Level knob for that channel, and then sent to the output.
The Level knobs set the scale factor for each polyphonic input channel. The default range for all Level knobs is unipolar 0-1x.
A "Level range" option in the module context menu lets you specify a different range that is used for all the knobs.
- 0-1x (default)
- 0-2x
- 0-5x
- 0-10x
- +/- 1x
- +/- 2x
- +/- 5x
- +/- 10x
The default (initialize) level for each knob always starts out at 1x, regardless of the range. Of course the default can be overriden by the standard Venom parameter context menu option.
By default the number of output channels matches the number of input channels. Knobs for channels above the output count are ignored.
There is a "Polyphony channels" option in the module context menu that lets you override the default and select a specific output channel count. Input channels and knobs above the specified channel count are ignored. Monophonic inputs are cloned to match the selected channel count. If the input channel count is poly but less than the selected channel count, then missing channel inputs are assumed to be constant 0 volts, meaning the output will also be 0 volts.
The number of polyphonic channels at the output is displayed in the LED panel. The display will be yellow if the number of output channels is greater than or equal to the input channel count. The display will be red if the selected channel count is less than the input channel count.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If Poly Scale is bypassed then the input is passed unchanged to the output.
Replicate each channel of a polyphonic input with a variable detune spread, and merge the results into a single polyphonic output.
Up to four auxilliary poly inputs may also be cloned via the Auxilliary Clone Expander. Note that auxilliary outputs on the expander are not detuned.
Sets the number of unison channels for each input channel, from 1 to 16.
Monophonic bipolar CV modulates the unison count, with each 1/3 volt representing 1 unison voice. The CV is summed with the Count knob value, and the result clamped to the range 1 to 16.
Sets the detune spread for each source channel, measured in semitones. This parameter has no effect if the unison count is 1. The unison voices will be distributed evenly across the spread. The increment between voices = Spread / (Count - 1).
Monophonic bipolar input modulates the detune spread. The CV input is scaled so that 10V matches the DETUNE knob range, and then summed with the detune knob value to determine the effective detune spread. A module context menu option is available to use a V/Oct scale for the CV instead.
This color coded button specifies how the detune spread is applied to each replication set.
- Off (gray) = Center - The unison voices are divided evenly above and below the input V/oct. The range is (Input - Spread/2) to (Input + Spread/2).
- Green = Up - The unison voices start at the input V/oct and move up. The range is (Input) to (Input + Spread).
- Red = Down - The unison voices start below the input and end at the input V/oct. The range is (Input - Spread) to (Input).
This color coded button specifies the range of the detune knob:
- Off (gray) = 1 semitone = 1/12 Volt
- Blue = 1 octave = 12 semitones = 1 Volt
- Green = 5 octaves = 60 semitones = 5 Volts
Each channel from the polyphonic input is replicated based on the unison count as long as the total replicated channel count does not exceed 16. Input channels that cannot be replicated the full amount are ignored.
The absense of input is treated as monophonic constant 0V.
For each channel appearing at the input, the corresponding LED above glows yellow if the channel could be successfully replicated, and red if it could not be replicated. LEDs beyond the input channel count remain off (black).
The GRP button controls how the replicated channels will be grouped at the output
- Input channel (yellow, default) - All the replicated channels for a given input channel will be grouped together at the output.
- Input set (blue) - The input channels will be grouped together in order as a set, and then the set will be replicated at the output.
All of the replicated channels are merged into the single polyphonic output. The order of the channels is dependent on the GRP button. Detune spread for each input channel goes from low to high (unless the detune CV creates a negative spread)
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If Poly Unison is bypassed then the input is passed unchanged to the output.
Five independently configurable push buttons.
Each button has custom menu options that allow you to tailor the button to your needs
- Trigger - A 1 msec On value trigger is output each time the button is pressed.
- Gate (default) - The On value is output while the button is pressed.
- Toggle - The button changes state each time the button is pressed. Toggle button states are stored with patches, selection sets, and presets, and are restored when the patch, selection set, preset is loaded.
- 10 V (default)
- 5 V
- 1 V
- 0 V
- -1 V
- -5 V
- -10 V
- Custom
If Custom is chosen, then a Custom ON value menu option is added that lets you type in any value between -100 and 100. You can enter simple mathematical expressions - all of the keyins that work for setting a knob value also work for the custom value.
Same values as On except the default is 0 V and the Custom value adds a Custom OFF value menu option.
- Red
- Yellow
- Blue
- Green
- Purple
- Orange
- White (default)
- Dim Red
- Dim Yellow
- Dim Blue
- Dim Green
- Dim Purple
- Dim Orange
- Dim Gray
- Off
Same values as Off except the default is Dim Gray
Determines the number of channels to output. All channels will be identical. The default is 1 (mono).
The module context menu includes options that configure all buttons simultaneously. The options and values are the same as for individual buttons, except Custom values are not supported. You must configure each button individually if you want custom values.
If all buttons currently share the same value, then the current value is displayed in the menu. If at least one button is different then the current value is empty.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus. However, the rename function is modified slightly. Renameing a button will automatically rename the corresponding output port, and vice versa.
All outputs are constant monophonic 0 V when PUSH 5 is bypassed.
Compact polyphonic bipolar VCA (ring modulator) and mixer inspired by Mutable Instruments Blinds.
By default this module behaves the same as the Audible Instruments Quad VC Polarizer, which in turn emulates the Mutable Instruments Blinds hardware. All the functionality has been shrunk down to 5hp, very similar to the Southpole Bandana module that was never officially ported to VCV 2.
There are 4 independent module channels, each with an Input, Output, Level attenuverter, and Level CV with Level Amount attenuverter.
The formula for the output is Vout = Vin x NetLevel%, where NetLevel% = (Level% + VCV/Vunity x CV%), clamped to +/- 200%
The input port is normalled to 5V, and the unity voltage is 5V. The way the math works, you can attenuate an input signal and add an offset by patching the input to the Level CV input, and leaving the Input port unpatched. The Level knob becomes the offset, and the CV Level knob the attenuator.
Each output is normalled to the output below so you can mix the outputs.
The Venom Quad VC Polarizer extends the Blinds functionality with support for polyphony, plus a number of options.
For each output port, the number of polyphony channels is the maximum channel count found across all inputs that contribute to the output. So if all inputs are monophonic except for 5 channel polyphony at the first CV input, and the first output is unpatched, and the second output is patched, then the output will be 5 channel polyphony.
The polyphony acts as would be expected when the input and output channel counts match.
Monophonic input is automatically replicated to match the output channel count.
Polyphonic inputs with fewer channels assume constant 0V for any missing channels.
Sets the level of oversamping to apply to all inputs and outputs. Oversampling can be useful for controlling aliasing that would otherwise be introduced by ring modulation and/or clipping.
- Off (dark gray, default)
- x2 (yellow)
- x4 (green)
- x8 (light blue)
- x16 (dark blue)
- x32 (purple)
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
Sets the input voltage if the port is not patched
- 5V (yellow, default)
- 10V (light blue)
Determines the type of CV input that is accepted, where unity is 5V or 10V. The unipolar mode effectively creates more typical 2 quadrant VCAs instead of the default 4 quadrant VCAs (ring modulators)
- Unipolar clamped (green) = 0V to unity
- Bipolar clamped (orange) = -unity to unity
- Bipolar unlimited (purple, default)
Determines the CV voltage that represents 100%
- 5V (yellow, default)
- 10V (light blue)
Optional clipping applied to the output
- Off (dark gray, default)
- Hard +/- 10V (white)
- Hard +/- 5V (yellow)
- Soft +/- 12V (light blue) = tanh saturation
- Soft +/- 6V (dark blue) = tanh saturation
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are monophonic 0V when Quad VC Polarizer is bypassed.
Uses polyphony to recursively process an input via SEND and RETURN up to 16 times. Polyphonic inputs may be used, which will limit the number of recursion passes to less than 16 for each input channel. There are no limits placed on any of the input or output voltages.
Specifies how many recursion passes should be applied to each input channel. The input channel count mulitiplied by the recursion count must be less than or equal to 16, else some input channels will be dropped.
The display is yellow if all input channels can recurse the requested number of times. The display is red if one or more input channels is dropped.
The Input is the signal to be recursively processed, and the result is sent to the Output. The number of output channels will match the input unless channels had to be dropped due to channel count limitations during send and return.
The Send output and Return input channel count can be computed as input channels multiplied by recursion count. The maximum number of input channels is the integral division of 16 divided by recursion count. Input channels that exceed the computed maximum are dropped.
If there are 3 input channels and a recursion count of 5, then Send/Return channels 1-5 will be for input channel 1, 6-10 for input channel 2, and 11-15 for input channel 3. If the recursion count is bumped up to 6 while the input channel count remains 3, then Send/Return channels 1-6 are assigned to channel 1, 7-12 channel 2, and channel 3 is dropped because there are not enough channels remaining to complete 6 recursive passes.
The Return input is normalled to the Send output.
Inputs can be recursively scaled and offset within the RECURSE module itself.
The SCALE input and knob value are multiplied to establish the scale factor. The scale factor is then multiplied by the input value, so RECURSE can perform ring modulation.
The OFFSET input and knob value are added to establish the offset that is added to the input.
By default, the SCALE operation occurs before the OFFSET operation. A context menu option lets you choose to peform the OFFSET before SCALE. A small light glows yellow next to the operation that is performed first.
The SCALE and OFFSET inputs support polyphony. However, only channels that correspond to what appears on the IN input will be used, extra channels will be ignored. Each SCALE or OFFSET channel will be applied to all relevant recursive steps for the corresponding IN input.
The unlabeled Modulation Mode knob determines when the SCALE and OFFSET operations take place. There are 4 values:
- 1Pre = Once before the first Send only
- nPre = Before every recursive Send
- nPost = After every recursive Return
- 1Post = Once after the final Return
Since the Return is normalled to the Send, it is possible to generate a polyphonic series of constant voltages using only the RECURSE module. For example, leave all inputs and the Return unpatched, set the Recursion Count to 16, the Scale to 1, the Offset to 1V, and the Mode to nPre. The SEND output will have 16 channels of integral values from 1 to 16. Change the Mode to nPost and the values will range from 0 to 15.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
The Input is passed unchanged to the Output when RECURSE is bypassed. The SEND will be monophonic 0V.
Recurse Stereo is identical to Recurse except the Input/Return inputs and Output/Send outputs are doubled to support left and right channels of a stereo pair.
The number of input polyphonic channels is strictly controlled by the Left Input. Any extra channels in the Right Input are ignored.
The Right Input is normalled to the Left Input.
In addition, The Left Return is normalled to the Left Send, and the Right Return is normalled to the Right Send.
The Recursion Count, Scale, Offset, and Modulation Timing settings are applied to both Left and Right identically.
Both left and right inputs are passed unchanged to the outputs when RECURSE STEREO is bypassed. The right input remains normalled to the left input while bypassed. Bypassed left and right send are monophonic 0V.
Transform CV or audio by mapping way point voltages to new values.
Reformation transforms incoming CV or audio by remapping 5 voltage way points (min, 1/4, 1/2, 3/4, max) to new values, and performing linear interpolation of intermediate values. The input may be configured to handle unipolar or bipolar signals, and the output can be independently offset to unipolar or bipolar. Each way point mapping is controlled by a combination of a slider and two attenuverted CV inputs. The resultant signal can be overdriven with hard or soft clipping at 20V peak to peak, and then attenuated back down to the desired level. CV inputs are available for both the drive and final level. Oversampling is available to control aliasing that would otherwise be introduced by the transformation and/or clipping.
Reformation is fully polyphonic, and all modulation can be driven at audio rates.
Reformation can be be used as a waveshaper and/or VCA and/or distortion effect (hard clipper or saturating limiter). CV control of each way point provides for amplitude modulation of specific regions of a waveform.
Each slider is assigned an input voltage according to its label above, and the slider value determines the re-mapped voltage for the given way point. The sliders are labeled in a relative way. The exact values depend on the chosen input polarity.
Polarity | MIN | 1/4 | 1/2 | 3/4 | MAX |
---|---|---|---|---|---|
Unipolar (0V - 10V) | 0V | 2.5V | 5V | 7.5V | 10V |
Bipolar (-5V - 5V) | -5V | -2.5V | 0V | 2.5V | 5V |
Each slider defaults to the way point input voltage (no change), which is marked by a bold line on the scale.
Below each slider is a pair of bipolar CV inputs, each with its own attenuverter. The attenuverted CV inputs are summed with the slider values to establish the effective mapping for each way point. The summed value is not constrained, so it is possible to modulate a signal outside the standard unipolar or bipolar voltage ranges.
The color coded IN button establishes the expected polarity of the input:
- Green (default) = Unipolar
- Red = Bipolar
The color coded OUT button establishes the polarity of the final output. The transformed signal is offset as needed to achieve the correct output polarity.
- Green (default) = Unipolar
- Red = Bipolar
Note that unipolar output is not guaranteed to be >= 0V unless one of the clipping options is enabled.
The drive amplifies the resultant signal prior to any clipping. The drive range is from 1 (no amplification) to 10 (multiply by 10), with the default at 2. The drive value is the sum of the knob value and the Drive input, clamped to a range from 1 to 10.
Note that unipolar inputs are offset -5V to become bipolar, prior to applying the drive.
The color coded CLIP button specifies the type of clipping that is applied.
- Gray = Off (no clipping)
- Yellow (default) = hard clipping at +/- 10V
- Orange = soft tanh clipping at +/- 10V
The level knob and level CV input function as a typical voltage controlled attenuator that is applied after the drive and clipping. The effective attenuation is the product of the Level knob (ranging from 0 to 1) and the Level input divided by 10V. The attenuation is then clamped to a value between 0 and 1. The default level is 0.5. So in the absence of any clipping, the default drive of 2 coupled with the default level of 0.5 results in no change.
The final output is offset by +5V if the output is configured to be unipolar. It is possible for unipolar output to have negative values if clipping has not been applied.
The color coded OVER button specifies the amount of oversampling that is done to mitigate aliasing that can be introduced by the mapping transformation and clipping.
- Gray (default) = No oversampling
- Light Blue = x4
- Dark Blue = x8
Oversampling is relatively CPU intensive, and should only be applied when needed. Control voltage and low to medium frequency audio typically do not need oversampling. But the quality of moderately high frequency output can be improved by oversampling.
Note that oversampling cannot remove aliasing that may be present in inputs driven at audio rates. To get the best possible results, make sure that all audio signals at the IN, CV, DRIVE, or LEVEL inputs is clean.
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
The number of output polyphonic channels is set by the maximum number of channels found across all inputs. Monophonic inputs are replicated to match the output polyphony count. Polyphonic inputs with fewer channels are assigned constant 0V for the missing channels.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
The Input is passed unchanged to the Output when REFORMATION is bypassed.
Rhythm Explorer is a trigger sequencer that stochastically generates repeating patterns on demand. It is heavily inspired by the Vermona randomRHYTHM Eurorack module, though no attempt was made to exactly replicate that module's features.
Rhythm Explorer looks complicated, but it is very simple to quickly begin creating interesting rhythms. Starting from the default initial settings, patch a 24 PPQN clock into the CLOCK input, and patch any combination of the GATEs, OR, XOR ODD, or XOR 1 outputs to your favorite drum modules. Adjust some of the sliders to something greater than 0, but less than 100, and press the RUN button. A repeating rhythm should emerge, which can be modulated by adjusting the sliders. Each time you press the DICE button you will get a brand new pattern that can be modulated via the sliders.
Random Rhythm uses a pseudo Random Number Generator (RNG) to establish a sequence of seemingly random numbers. However, the "random" sequence is dictated by a seed number - every time the RNG is reseeded with the same number, it generates the exact same sequence. With the initial setup, the reseed occurs after each set of 4 quarter notes, thus establishing a pattern. When the DICE button is pressed, a new seed number is generated, so the pattern will change.
Each division has its own density slider ranging from 0 to 100%, and each division also gets its own sequence of "random" numbers. Assuming all divisions are set to All mode, then when the slider value is greater than the current random number for that division, then the high gate will be issued for that beat. If the density is at 100%, then all beats will be played. If at 0%, then no beats will be played. The values in between do not specify the precise density for any given pattern, but rather specify the average frequency across all possible patterns.
All trigger and gate inputs have a transition to high threshold of 2 volts and transition to low threshold of 0.1 volts.
Trigger and gate high outputs are 10 volts, and low outputs 0 volts.
The Rhythm Explorer will not run properly until a 24, 48, or 96 PPQN (pulses per quarter note) clock is patched into the CLOCK input. By default Rhythm Explorer expects 24 PPQN. The "Clock input PPQN" option within the module context menu gives options for 24, 48 or 96 PPQN.
If the RUN input is not patched, then every press of the RUN button will toggle the run state on or off. The RUN button will be brightly lit while running, and off (actually very dimly lit) when not running.
Alternatively, the module run status can be controlled by patching CV into the RUN input. A high gate turns the run status on, and a low gate off. Again, the RUN light indicates the run status. When controlled by CV, the RUN button becomes momentary, and inverts the current run status. If currently running, then pressing the RUN button stops the module for as long as it is held down. Releasing the button starts the sequence again. Conversely, if the sequencer is stopped, then holding the button down starts the sequence, and releasing stops it again.
The RUN output gate will be high when the sequence is running, and low when stopped.
The sequence is reset to restart at the beginning of the phrase pattern every time the sequencer starts. A 1 ms trigger is also sent to the RESET output.
If you want to pause the sequencer, and then pick up where you left off without resetting, then externally mute the incoming clock instead of stopping the sequencer.
The run state is preserved across sessions, and stored with each patch and preset. If the module is running when inserted or loaded, then it will immediately perform a reset and begin running.
Pressing the RESET button or sending a CV trigger to the RESET input arms the sequencer to perform a reset and restart the phrase pattern from the beginning. The RESET button will glow brightly while in an armed state. By default the reset action will wait until the leading edge of the next clock pulse. For typical tempos, a 24 PPQN clock is fast enough that the reset is perceived as nearly instantaneous. The module context menu has a Reset Timing option where you can specify a different value for when the reset is applied:
- Clock
- Bar
- 1/2
- 1/4
- 1/8
- 1/16
- 1/32
- 1/2 Triplet
- 1/4 Triplet
- 1/8 Triplet
- 1/16 Triplet
- 1/32 Triplet
- Dotted 1/2
- Dotted 1/4
- Dotted 1/8
- Dotted 1/16
- Dotted 1/32 (Not available for 24 PPQN clock)
A 1 ms trigger is sent to the RESET output upon every reset action.
Pressing the DICE button or sending a CV trigger to the DICE input causes the sequencer to immediately sample a new seed value to establish a new pattern. The new seed value will not take effect until the start of the next phrase, whether due to a RESET, or reaching the end of the phrase and cycling back. The DICE button glows brightly while waiting for the new seed value to take effect. If you want the DICE to immediately take effect, then send a trigger to both the RESET and DICE inputs.
Typically the seed value is sampled from an internal RNG. Alternatively, you can provide your own unipolar CV seed value at the SEED input. The input is clamped to 0-10V. A sample and hold is used to save the seed value at the time of the dice action.
Wherever the seed value comes from, the sampled value is continuously sent to the SEED output.
The current seed value is preserved across sessions, and is saved with each patch and preset.
If the PAT OFF button is activated, then the RNG will never be reseeded, so the resultant output will be constantly changing, without any pattern.
If using CV SEED input, then the same effect can be achieved by using a 0V SEED input.
Note that the internal RNG will never generate a 0V seed value.
Normally the patterns are established by an internal RNG that has been seeded with the sampled seed value. Alternatively, any varying CV can be patched into the RAND input to override the internal RNG. Each division will sample the RAND signal at the appropriate time to establish the next "random" value to compare against the division slider threshold. Note that the seed value has no effect when using an external RAND source.
If the RAND input is monophonic, then all divisions will sample the same RAND input. But if you provide a polyphonic input with 8 channels, then each division will get its own "random" input. Note that if you patch a polyphonic input with fewer than 8 channels, then the missing channels will get constant 0V.
The result when using external RAND may or may not have a pattern, depending on the RAND signal. You may be able to patch the Rhythm Explorer PHRASE START output to your random source reset or sync input to establish a pattern that repeats at the beginning of each phrase.
The BAR knob sets the number of 1/4 notes that make up 1 bar or measure, with a value ranging from 1 to 16. The PHRASE knob sets the number of bars that make up one phrase, also with a range from 1 to 16. Upon completion of a phrase, the sequencer cycles back to the beginning of bar 1, and the pattern is reset. Each knob has a set of 16 lights above to show both the current count setting, as well as where in the cycle the sequencer is at.
Both BAR and PHRASE can be modulated via bipolar CV at the inputs below the knobs, which is added to the knob value. The scale is linear, with 0V representing 1, and 10V representing 16. The result is clamped to 0 - 10V (1 - 16 count).
The BAR START output issues a high gate lasting one clock pulse at the start of every bar. Likewise the PHRASE START output issues a gate at the start of each phrase.
The phrase start pulse is also sent to channel 9, and the bar start pulse to channel 10 of the GLOBAL polyphonic clock output.
There is a matrix with 8 columns, each column representing a single division. Each division column consists of a mixture of controls, inputs, and outputs arrayed vertically. The behaviour of each control/input/output is the same for each division.
The square division button at the top of each column indicates the currently selected division value for that column. Pressing the button cycles through the 15 available values, and right clicking presents a menu allowing you to directly select one of the values. The available values are
- 1/2 Note
- 1/4 Note
- 1/8 Note
- 1/16 Note
- 1/32 Note
- 1/2 Note Triplet
- 1/4 Note Triplet
- 1/8 Note Triplet
- 1/16 Note Triplet
- 1/32 Note Triplet
- Dotted 1/2 Note
- Dotted 1/4 Note
- Dotted 1/8 Note
- Dotted 1/16 Note
- Dotted 1/32 Note - Automatically disables (mutes) column if clock is 24 PPQN
Note that you may reuse the same division for multiple columns. Also note that the order of the columns can make a difference in the result depending on the mode selection (described later)
Some divisions will give irregular intervals if the division does not divide evenly into the total phrase length (phrase x bar)
Some 50% or 100% clock or gate widths will be incorrect and/or inconsistent if the clock PPQN is not high enough. (Gate/Clock widths are described later)
The table below lists the divisions with special requirements for regular intervals and/or consistent widths.
Division | Total Phrase Length | Clock PPQN |
---|---|---|
1/2 | Multiple of 2 | Any |
1/32 | Any | 48 or 96 PPQN |
1/2 Triplet | Multiple of 4 | Any |
1/4 Triplet | Multiple of 2 | Any |
Dotted 1/2 | Multiple of 3 | Any |
Dotted 1/4 | Multiple of 3 | Any |
Dotted 1/8 | Multiple of 3 | Any |
Dotted 1/16 | Multiple of 3 | 48 or 96 PPQN |
Dotted 1/32 | Multiple of 3 | 96 PPQN |
Each slider specifies a threshold at which any given division beat is likely to issue a high gate. Typically the values are unipolar ranging from 0 to 100%. Each density can be modulated by the division density CV input, and/or the Global density CV input.
The density slider knob blinks bright yellow each time the beat fires for that division. Note that the mode logic used for OR, XOR ODD, and XOR 1 outputs can be different then what is used for the individual division outputs, so the blinking sliders may not match the OR, XOR ODD, or XOR 1 outputs.
The mode can influence whether a given beat will fire. Pressing the square button cycles through the available values, and right clicking provides a menu to directly select any one value.
- ALL - All beats that meet the random threshold will fire. Note that the left most division is fixed at ALL because it cannot be influenced by any other divisions.
- LIN - Linear mode, meaning that the beat will be blocked if one of the divisions to its left is firing at the same time. If all divisions are set to LIN (disregarding the 1st one of course), then there will never be more than one division playing at a time, the definition of linear drumming.
- OFF - Offbeat mode, meaning that the beat will be blocked if one of the divisions to the left coincides with this division's beat, regardless whether the left division actually fires or not. This is a special case of linear drumming. For example, if division 1 is 1/4 note, and division 2 is 1/8 note with OFF mode, then the 1/8 will never fire with the 1/4 beats - it will fire only on the "and" of each beat.
- --- Global default, meaning the division will inherit the mode that is specified at the global level.
- ALL - RESET (dashed square bracket) - Same as ALL, except the linear and offbeat computations are reset such that divisions to the left do not effect linear or offbeat divisions to the right.
- ALL - NEW (solid square bracket) - Same as ALL - RESET, except an additional channel is added to the OR, XOR ODD, and XOR 1 outputs, and this division and those to the right are assigned to the new channel.
The mode can be overridden by division Mode CV.
Pressing the mute button toggles between muting and unmuting the division GATE output. Note that a muted division will never block any division to the right that is set to LIN mode. There is no mute CV - use the density CV if you need to effectively mute via CV.
This bipolar CV input modulates the division density at a rate of 10% per volt. It is additive with the density sliders and the global density CV. The sum of slider plus global CV is clamped to 0-10V prior to adding the division CV, so a CV of -10V is guaranteed to effectively mute the division.
The division mode CV input overrides the value set by the button. The CV actually sets the column's mode button to match so you get a visual indicator of the active mode.
The mode values are as follows:
- 0V = ALL
- 1V = LIN (linear)
- 2V = OFF (offbeat)
- 3V = --- (global default)
- 4V = ALL - RESET
- 5V = ALL - NEW
The CV value is rounded to the nearest integer, and clamped to be within the valid range.
Each division outputs an appropriately divided clock division for that division. Each division clock is also sent to one channel in the GLOBAL CLOCK poly output.
For each issued beat, a gate is sent to the GATE output. Each division gate is also sent to one channel in the GLOBAL GATE poly output.
By default both the CLOCK and GATE output gate widths match the input clock gate. The module context menu has options to select alternate widths.
-
Clock output width
- Input clock pulse
- 50%
-
Gate output width
- Input clock pulse
- 50%
- 100% (consecutive high gates are tied together)
Some divisions have special requirements for total phrase lengths and/or minimum clock PPQN in order to achieve correct and consistent widths. See the Division Button section above.
To the right of the 8 division matrix is a global column that can serve multiple purposes
The global mode has the same values as the division mode, except there are no --- (global default), ALL - RESET, or ALL - NEW values available.
The global mode serves two purposes:
- It defines the mode used to compute the OR, XOR ODD, and XOR 1 outputs.
- If a given division has its mode set to --- (Gobal Default), then the global value also defines the mode for that division.
The global mute button mutes all the division gate outputs, as well as the OR, XOR ODD, and XOR 1 outputs. Each press toggles between muting and unmuting the outputs.
The global density CV can modulate the density for all divisions. If the input is monophonic, then the value is applied to all divisions. If the input is polyphonic, then each channel is directed to the appropriate division. The global CV can be bipolar, with each volt representing 10%. The global CV value is summed with the division density slider value and then clamped to a valid range before any division CV is applied.
The global mode CV overides the global button mode value. If monophonic, then it is applied to all divisions. If polyphonic then each channel is directed to the appropriate division mode. The only way to have different modes for divisions used in the OR output is via the GLOBAL MODE CV. Note that channel 1 is for the first (left most) division, even though the 1st division does not have mode CV input - it simply ignores any value there.
The voltage values are the same as for the Division Mode CV input, except the value is capped at 2V.
The Global Mode CV updates the value of the Global Mode button, showing the value that is assigned to channel 1. You can see the global modes that are assigned to all 8 divisions by hovering over the Global Mode button.
The global clock output is polyphonic with 10 channels
- Channels 1 through 8 are for the clocks for divisions 1 through 8
- Channel 9 is for the Phrase Start clock
- Channel 10 is for the Bar Start clock
The global gate output is polyphonic with 8 channels, one for each division.
The vertical slider switch controls whether the division density sliders are unipolar from 0% to 100%, or bipolar from -100% to 100%
Normally the sliders are set to unipolar. But if controlling the density via CV, then you may want to manually modulate the density up or down during performance, hence the bipolar mode.
When in normal unipolar mode, the sum of the slider value and global value is clamped to a range of 0 to 100 before being added with the division CV input.
But when in bipolar mode, the slider and global sum is clamped to a range of -100 to 100 before being added with the division CV input. Only then is the final density value clamped to a range of 0 to 100.
The density Init button will reset all division density sliders to 0%
The Lock button will lock the division values, division and global modes, and the density polarity to their current values so as to prevent inadvertant changes while manipulating the density sliders during a performance.
In addition to the individual division gate outputs, there are three outputs where the individual division gates are combined into one stream of gates.
The OR output simply combines all gates, with simultaneous beats across two divisions resulting in one beat.
The XOR ODD output only allows the beat through if there are an odd number of simultaneous beats. An even number of simultaneous beats effectively cancel each other out.
The XOR 1 output only allows a beat through if there is only one beat across all divisions - all simultaneous beats are blocked.
In addition, the GLOBAL MODE further defines which beats are allowed through, using the same logic as for the individual gates. Note that if all the global modes are set to linear or offbeat mode, then the OR, XOR ODD, and XOR 1 will all emit identical patterns since by definition, those modes don't allow simultaneous beats.
These outputs are normally monophonic, combining the beats of all 8 divisions. But the outputs become polyphonic if one or more divisions are assigned ALL - NEW mode. The total number of channels equals 1 + the number of ALL - NEW modes.
There is a Vermona randomRHYTHM preset available that configures the Rhythm Explorer to make it easy to get a flavor of what it would be like to actually use the Vermona hardware. The Phrase is set to 1 and Bar to 4, like the Vermona 4/4 time. It configures the divisions as 1/4, 1/8, 1/16, 1/4T, 1/4, 1/8, 1/16, 1/4T. All divisions are assigned mode ALL except division 5 is assigned ALL - NEW. It also sets the Global Mode to Offset so the OR output will behave like the Vermona. In this way there are effectively two rhythm generators configured like the Vermona, exept they both share a common clock, dice, and reset. The OR output is polyphonic - an external split module is needed to separate the OR output into separate outputs for each rhythm generator.
Venom Themes are available via standard Venom context menus. But Rhythm Explorer has its own design for limited parameter locking, so the standard parameter locking menus are not available. Neither are custom default options available for parameters.
All outputs are monophonic 0V when the module is bypassed.
Polyphonic slew limiter and slope detector for both CV and audio processing.
When you slew an input signal, you limit the maximum rate at which the signal can change voltage. The slew rate is measured as the number of milliseconds to rise or fall 10 Volts. The Slew module provides independent Rise and Fall times that can be linear or curved. Slew times and shapes can be modulated at audio rates. A V/Oct input is provided to proportionally scale the Rise/Fall times as the input frequency changes.
There are many possible uses for this behavior
- Adding portamento (glide) to V/Oct pitch sequences
- As a crude low pass filter
- If using gate inputs, as an Attack, Sustain, Release envelope generator
- If the input is fully rectified to positive voltages, then a fast rise time with slow fall time can function as an envelope follower
- As a waveshaper, with modulated time and/or shape providing a dynamic shifting sound
In addition to slewing an input signal, the Slew module also provides gate outputs indicating whether the slewed output is rising, falling, or flat.
When enabled (green), the Fall and Rise time knobs are scaled to be suitably fast for slewing audio rate inputs.
This color coded button sets the oversampling rate used to mitigate aliasing. Oversampling is usually only needed when slewing audio inputs.
- Off (gray - default)
- x2 (yellow)
- x4 (green)
- x8 (light blue)
- x16 (dark blue)
- x32 (purple)
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
The Fall and Rise times specify how many milliseconds it takes to rise or fall 10 Volts.
Each parameter has a top knob to set the base value and a CV input with attenuverter knob to modulate the base value.
The time knobs are scaled exponentially, and have two different scales depending on whether Fast is enabled or not.
- Minimum (counterclockwise) - 7.8125 msec
- Noon (default) - 250 msec
- Maximum (clockwise) - 8000 msec
With both Rise and Fall set to the default value of 250 msec, Slew will convert a 2 Hz 10V peak to peak square wave into a 10V peak to peak triangle wave.
- Minimum (counterclockwise) - 0.060223 msec
- Noon (default) - 1.9111 msec
- Maximum (clockwise) - 61.155 msec
With both Rise and Fall set to the default value of 1.9111 msec, Slew will convert a 261.63 Hz (C4) 10V peak to peak square wave into a 10V peak to peak triangle wave.
The Rise and Fall CV inputs can be inverted and/or attenuated by attenuverter knobs that range from -100% to 100%, with the default noon value at 0%.
Each +1V will double the time, and -1V will halve the time.
Note that Rise and Fall times are precise when using a linear shape (0% curve). If using a 100% curve shape, then the time represents approximately a 9 Volt change instead of 10 Volts.
The slewed Rise and Fall can be independently set to be linear or curved. If curved, then large input changes move faster than small input changes.
Rise and Fall each have a shape knob with fully counter-clockwise being linear, fully clockwise curved, and noon a blend of the two. The knobs are scaled to represent the percentage of curvature, with 0% being linear.
The shapes can be modulated via shape CV input ports with attenuverter knobs. The attenuated CV is summed with the knob value. The modulation is scaled at 10% curve per Volt.
This is the raw input you want to slew.
This CV input is used to scale slew rates proportionally as your input frequency changes. Each +1V halves the Rise and Fall times, and -1V doubles the Rise and Fall times. This modulation is great for using Slew as a waveshaper.
There are three gate output ports that indicate the slope of the slewed output
- RISE - 10V when rising, else 0V
- FALL - 10V when falling, else 0V
- FLAT - 10V when steady (not changing), else 0V
Note that gate outputs can be noisy when processing audio inputs, especially when oversampling is enabled.
This is the final result of the slew processing.
All inputs and outputs are fully polyphonic. The number of output polyphonic channels is set by the maximum number of channels found across all inputs. Monophonic inputs are replicated to match the output polyphony count. Polyphonic inputs with fewer channels are assigned constant 0V for the missing channels.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
The IN (raw) input is replicated at the OUT (slew) output when Slew is bypassed. All other outputs are constant monophonic 0V.
Shaped VCA is a stereo polyphonic voltage controlled amplifier with a variable response curve, and optional hard/soft clipping, ring modulation, amplitude modulation, and oversampling.
The Shaped VCA can function as a typical voltage controlled amplifier or attenuator, or ring modulator, or amplitude modulator, or constant voltage source, or waveshaper, depending on which inputs are patched and how parameters are configured.
This color coded switch establishes the range of the Level knob amplification.
- yellow (default) = 0 to 1
- green = 0 to 2
- dark blue = 0 to 10
- pink = -1 to 1
- orange = -2 to 2
- purple = -10 to 10
This color coded switch establishes the VCA mode
- dark gray (default) = Unipolar 0-10V clipped CV (2 quadrant)
- white = Bipolar +/- 10V unclipped CV (4 quadrant)
- dark blue = Unipolar 0-5V clipped CV (2 quadrant)
- green = Bipolar +/- 5V unclipped CV (4 quadrant)
When using 0-5V or +/- 5V, the CV input is amplified x2 to get better exponential or logarithmic shaping. This makes the +/- 5V mode ideal for ring modulation because +/- 5V bipolar modulator and carrier inputs will result in +/- 5V bipolar output.
This color coded switch establishes how the output is clipped
- dark gray (default) = Off - No clipping
- yellow = hard clipped at +/- 10 Volts
- orange = soft clipped at +/- 10 Volts using an approximated tanh algorithm to provide saturation.
It is highly recommended that hard or soft clipping be applied if performing ring modulation with a logarithmic response curve using the original algorithm.
This color coded switch establishes the amount of oversampling used to mitigate audio aliasing that may be introduced by clipping or non-linear response curves.
- dark gray (default) = Off - No oversampling
- yellow = x4 oversampling
- green = x8 oversampling
- light blue = x16 oversampling
- dark blue = x32 oversampling
Oversampling is typically not needed for most VCA operations. But it may be useful with high frequency audio outputs when clipping and/or non-linear response curves are applied. Oversampling is highly recommended if performing ring modulation or amplitude modulation with a logarithmic response curve.
Oversampling uses significant CPU resources, so it is best to use the minimum oversampling value that gives the desired output.
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
Sets the maximum gain applied to the input signal(s). The range is dependent on the Range paramater. The default value is unity gain, regardless which range is chosen.
Attenuates or inverts and attenuates the gain. The exact behavior is dependent on the Mode parameter setting. Regardless what mode, 10V equals full maximum level, and 0V equals zero output. The effective gain for in between values is dependent on the Curve parameter and CV input. When in unipolar mode, the level input is clamped to a 0 to 10 volt range.
The Level input is normaled to 10V so that unpatched level input results in the full gain specified by the Level knob. In this way Shaped VCA can operate as an attenuator or amplifier, without voltage control.
The Bias knob can add an offset ranging from -5V to 5V to the Level CV input. It is useful for converting a bipolar Level input to unipolar so it can be wave shaped by the Curve response. It is also useful for cross fading between ring modulation and amplitude modulation when the VCA Mode is set to bipolar. The bias is applied prior to any exponential or logorithmic shaping of the CV input.
Controls the response curve of the level CV input, with full clockwise (100%) giving an approximated logarithmic response, noon (0) a linear response, and full counterclockwise (-100%) an exponential response. Intermediate values cross fade between the extremes and linear.
The default value is 0 = linear response curve.
The Curve CV input is multiplied by 10 and then summed with the Curve knob value to establish the effective response curve. The final effective curve level is clamped to +/- 100%.
The Curve CV input is normaled to 0V.
Logarithms aren't defined for negative values, but ring modulation needs to support negative values. So to make logarithmic responses work with ring modulation, the approximated logarithm of the absolute value is used and then multiplied by the sign of the original value (1 or -1).
Exponential shapes also support negative values.
The original version of Shaped VCA used different algorithms for logarithms and exponentials. The original logarithm produced wicked high voltage spikes that required clipping, and the exponential effectively used the absolute value of the input.
Starting with version 2.5.0, the improved logarithm formula was used, but the exponential formula still used the absolute value.
Negative exponential values were introduced in version 2.8.0.
The original algorithms are probably not what is wanted, but to support any old patches that relied on the old behavior, there is an Exp/Log algorithm context menu option to force the use of prior alogorithms.
- Corrected = the newest preferred alogorithms. Shaped VCA modules placed into a new patch default to this option.
- Intermediate = the corrected logarithm algorithm, but absolute value exponential algorighm. Patches created from v2.5.0 through v2.7.0 default to this option.
- Original = original logarithm and absolute value exponential. Patches created prior to v2.5.0 default to this option.
Note that the Intermediate and Original options have no effect if using 0-5V unipolar or +/-5V bipolar VCA modes. These VCA modes did not exist prior to v2.8.0, so there is no prior behavior to support, and the corrected algorithms are used.
The Right input is normaled to the Left input. The Left input is normaled to 10V so that Shaped VCA without any patched inputs can function as a constant CV source with the Level knob setting the value. The 10V normaled input is also convenient for using Shaped VCA as a waveshaper for the Level input.
After applying the effective gain to the inputs, the final result is sent to the Left and Right outputs.
This color coded switch can apply an offset to the final output. The output offset is applied before any clipping.
- dark gray (default) = Off - No offset
- red = -5 volt offset
- green = +5 volt offset
- Inputs are upsampled if using oversampling
- Bias applied to Level CV input
- Level CV input x2 if using 0-5V or +/- 5V VCA mode
- Exponential or logarithmic shaping applied
- Shape result attenuates the final level
- Final level attenuates the input(s)
- Output bias applied
- Clipping applied
- Output band limited and downsampled if using oversampling
Set VCA Mode button to Unipolar 0-10V
Set Bias knob to 0V
Patch envelope or other CV to Level CV input
Patch audio or CV to Left and/or Right input.
Set VCA Mode button to Bipolar +/- 5V
Set Level knob to 1.0
Set Bias knob to 0V
Patch modulator to Level CV in
Patch carrier to input
Set VCA Mode to Unipolar 0-10V (or Bipolar +/- 10V if you are worried about unwanted clipping)
Set Level knob to 1.0
Set Bias knob to +5V
Patch modulator to Level CV in
Patch carrier to input
Set VCA Mode button to Bipolar +/- 5V
Set Level knob to 0.5
Adjust Response Curve knob to desired shape
Patch bipolar signal to Level CV in
Leave input unpatched
Set VCA Mode button to Unipolar 0-10V (or Bipolar +/- 10V if you are worried about unwanted clipping)
Set Level knob to 1.0
Set Bias knob to +5V
Adjust Response Curve knob to desired shape
Patch bipolar signal to Level CV in
Leave input unpatched
Set Output Offset button to -5V
Set VCA Mode button to Bipolar +/- 5V
Set Level knob to 0.5
Set Bias knob to -5V
Adjust Response Curve knob to desired shape
Patch unipolar signal to Level CV in
Leave input unpatched
Set Output Offset button to +5V
Set VCA Mode button to Unipolar 0-10V (or Bipolar +/- 10V if you are worried about unwanted clipping)
Set Level knob to 1.0
Set Bias knob to 0V
Adjust Response Curve knob to desired shape
Patch unipolar signal to Level CV in
Leave input unpatched
The number of output polyphonic channels is set by the maximum number of channels found across all inputs. Monophonic inputs are replicated to match the output polyphony count. Polyphonic inputs with fewer channels are assigned constant 0V for the missing channels.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
The Left and Right inputs are passed unchanged to the Left and Right outputs when the module is bypassed. The Right input remains normaled to the Left input while bypassed. However, the left input is not normaled to 10V while bypassed.
Converts spherical coordinates r, theta, phi into cartesian coordinates X, Y, Z using standard physics definitions:
x = r x sin(theta) x cos(phi)
y = r x sin(theta) x sin(phi)
z = r x cos(theta)
When applied to audio rate inputs, it has an effect similar to ring modulation.
All inputs and outputs are fully polyphonic. The number of output channels is the maximum channel count found across all inputs. Monophonic inputs are replicated to match the output channel count. Polyponic inputs with fewer channels use constant 0V for any missing channels.
This color coded switch establishes the amount of oversampling used to mitigate audio aliasing that may be introduced by the conversion process.
- dark gray (default) = Off - No oversampling
- yellow = x2 oversampling
- green = x4 oversampling
Oversampling is typically not needed for most conversions. But it may be useful with high frequency audio outputs.
Oversampling uses significant CPU resources, so it is best to use the minimum oversampling value that gives the desired output.
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
This represents the radial distance r. Negative r values are accepted.
This represents the polar angle theta. It is scaled at 36V/degree, meaning 5V = 180 degrees. Any angle is allowed.
This represents the azimuthul angle phi. It is scaled at 36V/degree, meaning 5V = 180 degrees. Any angle is allowed.
Specifies the scale factor used for converting spherical radial distances into cartesian distances.
- 1:1 = +/-5V radial distance range specifies a 10V diameter sphere centered about the origin that is inscribed within a 10V x 10V x 10V cube.
- sqrt(3):1 = +/-5V radial distance range specifies a ~17.32V diameter sphere centered about the origin with a 10V x 10V x 10V cube inscribed within it.
Assuming that inputs are bipolar +/-5V, then a 1:1 ratio guarantees that all converted X, Y, and Z outputs are within +/-5V. However, not all possible +/-5V X, Y, Z coordinates are covered.
The sqrt(3):1 ratio guarantees that a bipolar +/-5V radial distance can cover all possible +/-5V X, Y, Z coordinates. However, some converted values may exceed the +/-5V range, depending on the input angles.
This represents the x cartesian coordinate, after conversion.
This represents the y cartesian coordinate, after conversion.
This represents the z cartesian coordinate, after conversion.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are constant monophonic 0V when Sphere To XYZ is bypassed.
A simple utility module with 5 polyphonic input/output pairs suitable for unity mixing of stacked inputs, and/or introduction of sample delays.
Nothing special here - just taking advantage of VCV Rack's built in capability to stack input cables. But it can be convenient if you need to distribute the unity mix to multiple destinations.
Each input starting with the 2nd is normalled to the output above, with a delay of 1 sample added. So an input at port 1 with an output at port 5 will yield 4 sample delays, plus the delay introduced by the module itself, for a total of 5.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
Each input is passed to the output below when the module is bypassed. However, the inputs are not normalled to the output above when bypassed.
A compact polyphonic VCA, mixer, attenuator, inverter, amplifier, and/or offset suitable for both audio and CV. The module includes options for bipolar VCA (ring mod), hard or soft clipping, and DC offset removal. Module functionality can be extended by a set of Mix Expanders.
There are four numbered inputs, each of which can be attenuated, inverted, and/or amplified by a level knob and CV input. Each modulated input can then be output to a dedicated numbered channel outupt and/or the modulated inputs can be summed to create a mix. There is also a 5th chain input, without modulation, that can be added to the mix. The mix can also be attenuated, inverted, and/or amplified by a mix level knob and CV input. Finally there are options to hard or soft clip the mix and/or remove DC offset, before sending the final mix to the Mix output. Oversampling is available for soft clipping to control any aliasing that might be introduced. The VCAs can be configured to have a linear or exponential response, and they can be unipolar or bipolar. Audio rate CV is supported so the VCA MIX 4 can do amplitude or ring modulation.
These knobs control the base level of each of the input channel's VCAs. The exact behavior of the knobs depends on the setting of the Mode button. Each base level may be modulated by the corresponding CV input.
Each level knob has a corresponding polyphonic CV input that is normalled to 10V. The CV attenuates the knob base level (or possibly amplifies and/or inverts, depending on VCA mode), with 0V representing off, and 10V representing unity. The exact behavior of the CV depends on the VCA mode.
The channel inputs for the VCAs that are subsequently summed in the MIX. Each input may be effectively normalled to a constant CV value, depending on the current Level Mode.
Each of the modulated inputs is sent to its corresponding numbered output, so the channel can function as a simple VCA, amplitude modulator, ring modulator, or constant CV source. Patched outputs may be removed from the final mix, depending on the setting of the Exclude button.
This knob controls the base level of the final mix. The incoming mix consists of the sum of the numbered channel outputs and the Chain input. The exact behavior of the Mix Level knob depends on the setting of the Level Mode button. The mix base level may be modulated by the mix CV input.
Patched channel outputs may be excluded from the mix, depending on the setting of the Exclude button.
The polyphonic mix CV input is normalled to 10V, and it attenuates the mix level (or possibly amplifies and/or inverts, depending on VCA mode). 0v represents off, and 10V is unity. The exact behavior of the CV depends on the VCA mode.
The polyphonic chain input allows multiple VCA MIX 4 to be connected in series, without consuming any of the numbered inputs. The chain input is normalled to 0V, and is added to the mix prior to the Mix level modulation.
The final mix is output here. The final mix output may be clipped and/or have DC offset removed, depending on the settings of the Clip and DC buttons.
The polyphonic channel count for each of the four numbered channel outputs is normally set to the maximum number of channels found across each CV and channel input pair. The count is set independently for each numbered channel output.
The final mix polyphonic channel count is normally the maximum channel count across the numbered outputs that are not excluded, as well as the chain and mix CV inputs.
Monophonic inputs are replicated to match the output polyphony. But polyphonic inputs with fewer channels than in the output send 0V for any missing channels.
There is one major exception when the Level Mode is set to poly sum, causing all outputs to be monophonic. In this mode, polyphonic signals at the numbered inputs and chain input are summed into a monophonic signal before any modulation. CV inputs are monophonic in this mode, meaning polyphonic CV channels 2 and above will be ignored.
The color coded mode button determines how the 4 channel and the mix knobs behave. The mode button cycles through 5 possible modes. The button context menu allows direct selection of any mode. Each mode is labeled for audio or CV according to typical usage, but all modes can be applied to both audio and CV.
- Unipolar dB (audio x2) (pink - default): Each knob ranges from -inf dB (0V) to +6.0206 dB (x2 amplification), with the default of 0 dB (unity) at noon. Unpatched channel inputs are normalled to 0V.
- Unipolar poly sum dB (audio x2) (purple): Same as Unipolar audio dB, except all polyphonic channel and chain inputs are summed to a single monophonic signal before being attenuated or amplified by the corresponding level knob. Unpatched channel inputs are normalled to 0V. Note that all CV inputs are treated as monophonic in this mode.
- Bipolar % (CV) (green): Each input level knob ranges from -100% (inversion) to 100% (unity) if the channel input is patched, or -10V to 10V constant CV when unpatched. Effectively this means unpatched channel inputs are normalled to 10V. Each input level knob defaults to 0% (or 0V) at noon. The Mix knob always ranges from -100% to 100%, with a default of 100%.
- Bipolar x2 (CV) (light blue): Each input level knob ranges from -2x to 2x if the channel input is patched, or -10V to 10V constant CV when unpatched. Effectively this means unpatched channel inputs are normalled to 5V. Each input level knob defaults to 0x (or 0V) at noon. The Mix knob always ranges from -2x to 2x, with a default of 1x (unity).
- Bipolar x10 (CV) (dark blue): Each input level knob ranges from -10x to 10x if the channel input is patched, or -10V to 10V constant CV when unpatched. Effectively this means unpateched channel inputs are normalled to 1V. Each input level knob defaults to 0% (or 0V) at noon. The Mix knob always ranges from -10x to 10x, with a default of 1x (unity).
The color coded VCA mode button determines how CV inputs are interpreted. The button cycles through 6 possible modes. The button context menu allows direct selection of any mode.
- Unipolar linear - CV clamped 1-10V (pink - default): A "normal" VCA with linear response. The base level can only be attenuated, and negative CV values are treated as 0V.
- Unipolar exponential - CV clamped 1-10V (purple): A "normal" VCA with exponential response. The base level can only be attenuated, and negative CV values are treated as 0V.
- Bipolar linear - CV unclamped (light blue): A VCA with linear response that is capable of ring modulation. Negative CV values invert the base level, and the base level is amplified by CV with magnitude greater than 10V. High frequency inputs can introduce aliasing.
- Bipolar exponential - CV unclamped (dark blue): A VCA with exponential response that is capable of ring modulation. Negative CV values invert the base level, and the base level is amplified by CV with magnitude greater than 10V. High frequency inputs can introduce aliasing.
- Bipolar linear band limited - CV unclamped (yellow): A VCA with linear response that is capable of ring modulation. Negative CV values invert the base level, and the base level is amplified by CV with magnitude greater than 10V. The channel input and CV input are band limited in an attempt to minimize audio aliasing when performing ring modulation or amplitude modulation.
- Bipolar exponential band limited - CV unclamped (green): A VCA with exponential response that is capable of ring modulation. Negative CV values invert the base level, and the base level is amplified by CV with magnitude greater than 10V. The channel input and CV input are band limited by a low pass filter in an attempt to minimize audio aliasing when performing ring modulation or amplitude modulation. However, the exponential response introduces significantly more high frequency content, so the low pass filter does not help very much.
The color coded DC block button determines when (or if) a high pass filter is applied to the final mix to remove any DC offset. DC offset removal always occurs after the final mix is attenuated (or amplified) by the Mix level knob.
- Off (dark gray - default): DC offset is not removed.
- Before clipping (yellow): DC offset is removed prior to any clipping. Note that subsequent clipping may re-introduce some DC offset.
- Before and after clipping (green): DC offset is removed both before and after any clipping. Note that only one DC offset removal is performed if clipping is not applied.
- After clipping (light blue): DC offset is removed after any clipping.
The last three DC offset options give identical results when no clipping is applied.
The color coded clip button determines how (or if) the final output is clipped.
- Off (dark gray - default)
- Hard post-level at 10V (white)
- Soft post-level at 10V (yellow)
- Soft oversampled post-level at 10V (orange)
- Hard pre-level at 10V (green)
- Soft pre-level at 10V (light blue)
- Soft oversampled pre-level at 10V (dark blue)
- Saturate (Soft oversampled post-level at 6V) (purple)
If clipping is off then there is no limit to the output voltage.
Hard clipping can produce significant aliasing if applied to audio signals.
Soft clipping provides tanh saturation. At moderate saturation levels there is little to no audible aliasing. But very hot signals can still lead to signfcant aliasing.
Soft oversampled clipping also provides saturation, but aliasing is greatly reduced.
The color coded exclude button determines if patched channel outputs are excluded or included in the final mix.
- Off (dark gray - default): patched output channels are included in the final mix
- On (red): patched output channels are excluded from the final mix
Oversampling is used by some Clip options as well as the VCA bandlimitted options. These options always use 4x oversampling.
There is a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
The numbered channel inputs are passed unchanged to their corresponding outputs when VCA Mix 4 is bypassed. The Mix output is monophonic 0V when bypassed.
A stereo compact polyphonic VCA, mixer, attenuator, inverter, amplifier, and/or offset suitable for both audio and CV. The module includes options for bipolar VCA (ring mod), hard or soft clipping, and DC offset removal. Module functionality can be extended by a set of Mix Expanders.
VCA Mix 4 Stereo is a stereo version of the VCA MIX 4, sharing the same features, but with the following differences:
- Each of the channel inputs and outputs, as well as the Chain input and Mix output are doubled to support left and right channels. Each stereo pair is controlled by its own single Level knob and CV input.
- Each right input is normaled to the corresponding left input. When using the bipolar Level mode, each input level knob produces constant CV only if both the left and right inputs are unpatched.
- The output channel count for each numbered channel is the maximum polyphony found across the corresponding left, right, and CV inputs.
- The output channel count for the Mix output is the maximum polyphony found across the chain and Mix CV inputs, as well as each numbered channel output that is not excluded from the mix.
- When bypassed, each channel's left input is sent unchanged to the left output, and right input to the right output. The right inputs are still normaled to the left inputs when bypassed. The Mix outputs remain monophonic 0V when bypassed.
All other behaviors are the same as for Mix 4.
A polyphonic oscillator with a robust array of features for the mad scientist sound designers amongst us, including available oversampling to give clean anti-aliased output regardless which functions are combined.
- Modes for audio, low frequency, and 0 Hz carrier linear FM
- The audio and low frequency modes can also be setup for triggered, retriggered, or gated one shot mode
- The triggered one shot mode can generate the undertone/subharmonic series
- Oversampling options to control aliasing
- Simultaneous outputs for Sine, Triangle, Square, and Saw waveforms, plus a highly configurable Mix
- Each waveform has controls/inputs for shape, phase, offset, and level
- The mix also has controls/inputs for shape (saturation or folding), global phase, offset, and level
- Even waveform (fundamental + even harmonics) available via saw morphing shape mode
- All inputs can be driven at audio rates, and nearly all can be oversampled
- All inputs support polyphony
- Level controls with configurable VCAs support AM and ring mod.
- Independent controls/inputs for exponential FM and true linear through 0 FM
- Linear FM input defaults to AC coupled, with an option for DC coupled
- Audio rate modulation of phase provides functionality often incorrectly referred to as through 0 linear FM.
- Independent inputs for hard sync (reset phase to 0), and soft sync (reverse waveform)
- Octave control
- Square pulse width range can be 0-100% or 3-97%
- Optional DC offset removal for the outputs
Watch this demo/tutorial video from Omri Cohen for an introduction to many of the VCO Lab features. It uses a slightly older version of VCO Lab, but it is still instructive.
Global controls and inputs are generally to the left.
The grid of controls, inputs, and outputs to the right control each waveform as well as the overall mix. One major exception is the Mix Phase controls on the far right are actually global phase controls.
VCO LAB is fully polyphonic - All inputs can process polyphonic signals.
The number of output channels is the maximum number of channels found across all inputs.
Monophonic inputs are replicated to match the number of output channels. Polyphonic inputs that have fewer channels use constant 0V for missing channels.
Momentarily forces all outputs to be monophonic - useful when the input polyphony count is reduced while the VCO Lab has feedback. The reset forces the correct output poly count to be computed. Without the Reset Poly button it would require temporary removal of all feedback to restore the correct poly count.
This color coded button controls the overall mode of the oscillator
- Audio frequency (white - default)
- Low frequency (orange)
- 0 Hz carrier (yellow)
- Triggered audio one shot (light blue)
- Retriggered audio one shot (dark blue)
- Gated audio one shot (green)
- Retriggered LFO one shot (pink)
- Gated LFO one shot (purple)
In 0 Hz carrier mode the oscillator is stalled, and requires linear FM input or phase CV input to produce a signal. Some of the controls and inputs have alternate behavior in this mode (labeled in an alternate color).
Phase distortion synthesis can be explored via the 0 Hz carrier mode. Setting the phase input attenuator to 40% will cause a 10V phasor change to exactly produce one wave cycle. The smoothest results will be achieved if all anti-aliasing is disabled for both the driving phasor, as well as the VCO Lab in 0 Hz carrier mode. For VCO Lab this means turning oversampling off, and disabling DPW anti-alias suppression.
If using any of the one shot modes, then the oscillator will not produce any output until it receives a trigger or gate at the Sync input.
- Triggered one shots will output exactly one complete cycle and then stop until the next trigger is received. If the cycle has not yet completed when a sync trigger is received, then the trigger is ignored. This works well for creating undertone or subharmonic series!
- Retriggered one shots will output one complete cycle and then stop until the next trigger is received. If another trigger is received before the cycle completion, then the wave will be reset to phase 0 and retriggered.
- Gated one shots work the same as retriggered except they only output as much of a single wave cycle as fits within the high gate period.
Regardless what mode is chosen, the full oscillator frequency range is accessible via CV modulation.
Whenever the frequency mode changes, the oversample rate is initialized to a default value. LFO modes always default to oversampling off. Audio and 0 Hz carrier modes initially default to x4 oversampling. A module context menu option is available to change the default audio and 0 Hz carrier oversample rate.
Like any digital oscillator, there is a hard upper frequency limit at 50% of the sample rate called the Nyquist frequency. However, VCO Lab does not limit any V/Oct voltage, so the oscillator may attempt to produce higher frequencies. If oversampling is not enabled, then the high frequencies are reflected back below the Nyquist frequency. If oversampling is enabled, then the amplitude of high frequencies is attenuated dramatically as the Nyquist frequency is approached.
Similarly, the module does not limit the low frequencies either. But here again there is a practical limit due to the limitations of single precision floating point numbers. When at very low frequencies, the oscillator may stall and cease oscillating. The stall point varies depending on the VCV engine sample rate, and the amount of oversampling. The stall point rises as the engine sample rate rises and/or as the oversampling rises.
This color coded button controls how much oversampling is applied to control aliasing of audio output.
- Off (dark gray - low frequency mode default)
- x2 (yellow)
- x4 (green - initial audio mode and 0 Hz carrier mode default)
- x8 (light blue)
- x16 (dark blue)
- x32 (purple)
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
Note that oversampling is CPU intensive, so best to use the lowest amount of oversampling that gives satisfactory results.
To further reduce CPU usage, oversampling may be disabled for individual inputs that are not being modulated at audio rates. Inputs that support oversampling have a context menu option to enable or disable oversampling, and an LED next to the port to indicate the current oversampling state:
- dark gray indicates that oversampling is off, or there is no input, so the current port setting is not applicable
- yellow indicates the input is being oversampled
- red indicates the input is not being oversampled
Square and Saw waves have the most high frequency harmonic content that can lead to more aliasing. To further reduce aliasing, VCO Lab uses DPW (Differentiated Polynomial Waveforms) when generating saw or pulse waves in audio mode.
DPW does not work well at low frequencies due to single precision floating point limitations, so DPW processing is automatically disabled when producing low frequency audio. This point varies depending on the sample rate and amount of oversampling.
DPW is always disabled when using any of the LFO modes, regardless the frequency. DPW is also disabled if the shape modulation is set to a morphing waveform, or one of the rectify modes.
There is a context menu option to disable DPW entirely for all audio modes.
This color coded button controls whether a high pass filter is applied to remove DC offset from all outputs
- Off (dark gray - default)
- On (yellow)
Sets the base frequency of the oscillator. The knob range varies depending on the Frequency Mode and the current selected Octave. Normally the knob uses an exponential scale, but in 0 Hz carrier mode it is a linear Bias with a very small range.
There is a module context menu option to measure the frequency in BPM (beats per minute) instead of Hz when using any of the LFO modes.
Below are the knob ranges by mode when the Octave is at 0. Note that the Octave does not modify the bias frequency when in 0 Hz carrier mode.
Mode | Minimum | Default | Maximum |
---|---|---|---|
Audio frequency | 16.352 Hz (C0) | 261.63 Hz (C4) | 4186 Hz (C8) |
Low frequency | 0.125 Hz (7.5 BPM) |
2 Hz (120 BPM) |
32 Hz (1920 BPM) |
0 Hz carrier bias | -0.08 Hz | 0 Hz | 0.08 Hz |
When in 0 Hz carrier mode, a 0 Hz bias produces a static linear FM sound. A non 0 bias provides a rhythmic motion to the sound - the higher the bias magnitude, the faster the rhythm.
When in audio or low frequency mode, the Octave knob adds or subtracts octaves to the Frequency knob.
When in 0 Hz carrier mode the knob sets the range for the linear FM depth. Low frequency modulation requires a smaller range, and higher frequency modulation a higher range to achieve the same degree of FM "folding"
The soft Sync reverses the waveforms upon the leading edge of an incomming trigger.
The trigger detection is implemented as a Schmitt trigger that goes high above 2V and goes low below 0.2V. Those thresholds allow for both unipolar and bipolar trigger signals to be used. A module context menu option allows you to change to a 0V high threshold and -2V low threshold, which only works for bipolar inputs, but synchronizes the trigger with the 0 crossing point.
This port supports oversampling that can be disabled via the port context menu.
This knob sets the depth of exponential frequency modulation.
This knob is disabled when in 0 Hz Carrier mode.
This input is for exponential FM CV.
This input is disabled when in 0 Hz Carrier mode.
This port supports oversampling that can be disabled via the port context menu.
This bipolar input can attenuate the Exp FM depth. A value of 10V represents 100%, and -10V inverts the depth at 100%.
This input is disabled when in 0 Hz Carrier mode.
This port does not support oversampling.
This knob sets the depth of through 0 linear frequency modulation
This input is for linear FM CV.
By default this input is AC coupled. There is a port context menu to enable DC coupled mode, which can save a small amount of CPU if you know that your input does not have any DC offset. A small LED to the lower right glows red when the input is DC coupled.
By default the linear FM is through-zero. There is a port context menu to disable through-zero mode. A small LED to the lower left glows red when the through-zero is disabled. Note that 0 Hz carrier frequency mode ignores this setting - it is always through-zero.
This port supports oversampling that can be disabled via the port context menu.
This input can attenuate the Lin FM depth. A value of 10V represents 100%, and -10V inverts the depth at 100%
This port does not support oversampling.
When in Audio or Low Frequency mode this input modulates the oscillator frequency at a scale of 1 volt per octave.
When in 0 Hz Carrier mode the input modulates the linear Bias at 0.02 Hz per volt.
This port does not support oversampling.
The Sync input resets the master oscillator phase to 0 upon the leading edge of an incomming trigger.
If using any of the one shot modes, the Sync is used to trigger the start of a wave cycle.
The trigger detection is implemented as a Schmitt trigger that goes high above 2V and goes low below 0.2V. Those thresholds allow for both unipolar and bipolar trigger signals to be used. A module context menu option allows you to change to a 0V high threshold and -2V low threshold, which only works for bipolar inputs, but synchronizes the trigger with the 0 crossing point.
This port supports oversampling that can be disabled via the port context menu.
The grid to the right contains columns of controls, inputs, and outputs for the four waveforms (sine, triangle, square, saw), and the mix.
The grid rows consist of Shape modulation, Phase modulation, Offset modulation, Level modulation, and Output.
For each modulation there is a base control knob plus a CV input and bipolar attenuator knob (attenuverter). The base modulation value is summed with the attenuated CV to get the final modulation amount.
All grid inputs support oversampling that can be disabled via the port context menu.
All four waveforms get different shape modulation. Each has a color coded Shape Mode button to determine the type of modulation used.
- log/exp (yellow - default)
- J-curve (orange)
- S-curve (purple)
- Rectify (light blue)
- Normalized Rectify (dark blue)
- Morph SQR <--> SIN <--> SAW (pink)
- Limited PWM 3%-97% (green)
- Skew (red)
- log/exp (yellow - default)
- J-curve (orange)
- S-curve (purple)
- Rectify (light blue)
- Normalized Rectify (dark blue)
- Morph SIN <--> TRI <--> SQR (pink)
- Limited PWM 3%-97% (green)
- Skew (red)
Controls the range of pulse width modulation, or the type of waveform morphing
- Limited PWM 3%-97% (yellow - default)
- Full PWM 0%-100% (orange) Values of 0% or 100% yield constant low or high output, with no oscillation
- Morph TRI <--> SQR <--> SAW (purple)
- log/exp (yellow - default)
- J-curve (orange)
- S-curve (purple)
- Rectify (light blue)
- Normalized Rectify (dark blue)
- Morph SQR <--> SAW <--> EVEN (pink)
- Limited PWM 3%-97% (green)
- Full PWM 0%-100% (red)
J-curve and S-curve are based on sigmoidal functions. The J-curve uses only half (positive or negative portion) of the sigmoidal function.
Rectify yields only 5 volts peak to peak (5 VPP) when shape is 100% or -100%.
Normalized Rectify attempts to keep the output 10 VPP regardless the shape value. It also shifts the output to keep it bipolar, prior to applying any offset.
The even waveform with the Saw Morph option is the same as what is produced by the Befaco Even module. It consists of the fundamental plus even harmonics.
The PWM percentages for sine, triangle, and saw waveforms represent the relative width of the positive portion of the bipolar waveform. The negative width always grows or shrinks in the opposite direction such that positive width plus negative width always adds to 100%, and the overall frequency remains constant.
The initial release of VCO Lab required 20 volts peak to peak CV to cover the entire shape range for Sin, Tri, and Saw. Starting with V 2.9.0 these ports now default to 10 volts peak to peak covering the entire range. These ports have a context menu option to revert to old behavior.
Below is a summary of the wave shaping when using the default (yellow) mode for all four waveforms.
Waveform | Negative modulation | No modulation | Positive modulation |
---|---|---|---|
Sine | exponential response | mathematical sine | logarithmic response |
Triangle | exponential rise, logarithmic fall | linear triangle | logarithmic rise, exponential fall |
Square | < 50% pulse width | 50% pulse width | > 50% pulse width |
Saw | exponential ramp | linear saw | logarithmic ramp |
The mix also has a color coded Shape Mode button
- Sum (No shaping) (yellow)
- Saturate Sum (orange - default)
- Fold Sum (purple)
- Average (No shaping) (light blue)
- Saturate Average (green)
- Fold Average (dark blue)
Summed shaping is best for smooth bipolar shape modulation and maximum shaping effect
Average shaping is best for maintaining 10V peak to peak output, as well as consistent unipolar output when applying Mix offset.
The image below shows the phase relationship between the four waveforms when no phase modulation is applied.
The phase of each waveform can be modulated relative to the other waveforms. This can have a dramatic impact on any resultant mix.
Each waveform can also be independently modulated at audio rates to achieve what is commonly mislabeled as linear through 0 frequency modulation. The effect is similar to, but definitely not the same as true through 0 frequency modulation.
When in 0 Hz carrier mode, phase modulation can be used to explore the world of phase distortion synthesis. Set the attenuator to 40% so that a 10V phasor delta equates to exactly one waveform cycle. Anti-aliasing on either the incoming phasor or the 0 Hz carrier will lead to unwanted distortion at phase discontinuities. So to get smooth results, oversampling should be off and DPW disabled when doing phase distortion synthesis.
The Mix phase modulation is actually a global modulation that is applied to all waveforms prior to mixing.
Adjusting the global phase can have a profound impact on the sound of soft sync.
Of course the global phase can be modulated at audio rates so that all waveforms get the same phase modulation.
Each waveform may be offset by as much as +5 or -5 volts, typically to achieve a unipolar output. Note that waveform offsets are only applied to the individual waveform outputs - they are not included in the mix output.
Offsets are applied before any level adjustment.
The mix also can be offset by as much as +5 or -5 volts, again typically to achieve a unipolar output. If trying to obtain a consistent unipolar output, it is often best to use one of the average options for the Mix Shape mode.
The offset is applied before any level adjustment
The sum of the Level knob and the attenuated CV is clamped to +/- 100% by default via hard clipping. There is a module context menu option to disable the limit for the entire module.
Each Level CV port has two context menu options in addition to the "Disable oversampling" option
- VCA unity = 5V: By default this option is disabled, and 10V equates to 100%. If enabled, then 5V equates to 100%. This is especially useful for ring modulation. The LED above and left of the port glows yellow when this option is enabled.
- Bipolar VCA (ring mod): By default this option is disabled, and the VCA is unipolar, meaning negative CV is ignored. If enabled, then the VCA responds to both negative and positive CV, which allows for ring modulation. The LED below and left of the port glows yellow when this option is enabled.
Each waveform has a color coded Lvl Asgn (Level Assign) button that controls how the waveform level attenuation is applied.
- Mix Output (yellow - default) - The level determines how much of the waveform is added to the mix. The waveform output will be unattenuated.
- Waveform Output (dark blue) - The level attenuates the waveform output, and the waveform is excluded from the mix.
- Both Waveform and Mix Output (green) - The level determines how much of the waveform is added to the mix, and also attenuates the waveform output.
Each waveform has its own dedicated output, plus there is a Mix output.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are monophonic 0V if the module is bypassed.
A smaller version of VCO Lab with only one waveform output at a time, without any mixing.
A Wave switch is added to select between Sine, Triangle, Square, and Saw.
The behavior of Shape modulation changes depending on the waveform selected. When Square waveform is selected, the three shape mode options are replicated cyclically for a total of 8 options, like all the other waveforms. This was done so that when cycling through the waveforms, the shape option does not change when you return to the original waveform.
Pretty much all other VCO Lab functionality is the same, except there is no mix, level assignment, or mix shaping.
A 3hp blank with standard Venom themes.
A polyphonic configurable wave folder and VCA.
The incoming signal is amplified and then folded at +/-5 volts a fixed number of stages. Increasing amplification increases the number of folds, with a limit set by the Stages count. The signal can be amplified once before any folding, and/or once for each folding stage. The folding can be made asymmetric by applying a bias voltage to the signal prior to any amplification. The final result is soft clipped at +/-6V by tanh saturation.
All amplification can be controlled via CV, thus making the wavefolder a VCA as well. The VCAs can be configured to be unipolar or bipolar, and they can process audio rate CV, so the module can also perform wave folded amplitude modulation or wave folded ring modulation.
Watch this video for a brief introduction and some example use cases. But please do read the rest of the documentation for some more details. Also watch this Omri Cohen video demonstrating a number of applications for the Wave Folder.
Controls the maximum amount of folding stages, which in turn limits the maximum number of folds. There are five possible values
- 2
- 3 (default)
- 4
- 5
- 6
Wave folding, ring modulation, and amplitude modulation can introduce many harmonics, which can lead to aliasing. Oversampling can be used to limit the amount of aliasing.
- Off
- x2
- x4 (default)
- x8
- x16
- x32
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
By default, oversampling is applied to all inputs.
Oversampling has a significant CPU cost, so best to apply the minimum amount that sounds good. LFO rate modulation should not need oversampling. The three CV input ports have a context menu option to disable oversampling for that port. These ports have a LED above and to the right of the port. It is off if there is no patched input, or if the OverSample button is set to Off. It is yellow if there is input and oversampling is applied. It is red if there is input and oversampling is active for the module, but disabled for that port.
Wave Folder is fully polyphonic. The number of output channels is the maximum number of polyphony channels found accross all inputs.
Inputs that match the output polyphony behave as expected. Monophonic inputs are replicated to match the output polyphony count. Polyphonic inputs with fewer channels get constant 0V for any missing channels.
Sets the amount of amplification applied to the input prior to any folding stages.
The total amplification is the sum of the knob and CV values. The CV can be attenuated and/or inverted by the Pre-amp CV Amount knob. CV can be driven at audio rates.
The knob ranges from 0 to 10, with a default of 1 (unity). But the CV is not limited, so the net amplification is unconstrained.
By default, the Pre-Amp VCA is unipolar, meaning any net amplification level less than zero is treated as zero. The port has a context menu option to use a bipolar VCA instead that can process negative values and invert the signal. The LED above and to the left of the port glows yellow if bipolar mode is enabled.
The Pre-Amp CV port also has the context menu option to disable oversampling, with the LED above and to the right indicating oversampling state.
Sets the amount of amplification applied at each stage of folding. See the note at the bottom of this section if you are interested in the exact mathematical formula.
The total stage amplification is the sum of the knob and CV values. The CV can be attenuated and/or inverted by the Stage Amp CV Amount knob. CV can be driven at audio rates.
The knob ranges from 0.5 to 10, but the CV is not limited, so the net amplification is unconstrained.
Note that the Stage Amp knob is scaled exponentially, but the CV is linear. The exponential knob scale makes it easier to dial-in the most useful values between 1 and 2.
By default, the Stage Amp VCA is unipolar, meaning any net amplification level less than zero is treated as zero. The port has a context menu option to use a bipolar VCA instead that can process negative values and invert the signal. The LED above and to the left of the port glows yellow if bipolar mode is enabled.
The Stage Amp CV port also has the context menu option to disable oversampling, with the LED above and to the right indicating oversampling state.
Actual stage folding formula
Without any stage amplification, the folding formula for each stage is Vout = clip(Vin) - (Vin - clip(Vin)), where clipping occurs at +/-5 volts.
This can be re-written as Vout = 2 x clip(Vin) - Vin
The stage amplification is only applied to the clip expression as follows: Vout = 2 x clip(Vin x Ampstage) - Vin
Sets the amount of bias voltage to add to the input signal prior to any amplification. Non-zero bias leads to asymmetric folding.
The total bias is the sum of the knob and CV values. The CV can be attenuated and/or inverted by the Bias CV Amount knob. CV can be driven at audio rates.
The knob ranges from -5 to 5, but the CV is not limited, so the net bias is unconstrained.
The Bias CV port has the context menu option to disable oversampling, with the LED above and to the right indicating oversampling state.
This is the input signal to be folded.
The input is always oversampled at the level selected by the OverSample button.
This is the final result of the wave folding.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
The poly input is passed through to the output if Wave Folder is bypassed.
A polyphonic distortion / waveshaper inspired by the Doepfer A-136 Eurorack module.
The Venom module implements most of the features of the Doepfer hardware, though not necessarily in exactly the same way, and then adds polyphony and additional modulation options.
Wave Mangler is designed to operate on bipolar +/- 5V signal inputs. An input offset is available to transform unipolar input to bipolar, and another offset is available to transform bipolar output to unipolar.
High and Low thresholds divide the +/- 5V input range into three regions: High, Middle, and Low. Each region can have a different amplification applied to it and the resultant amplified output components are summed to a final output that can be radically different than the original input. There are many CV modulation options to make the output extremely dynamic. All inputs work equally well with both low frequency and audio rate signals.
By default this button is disabled, and the main input is DC coupled.
If this button is enabled, then the main input is AC coupled, meaning a high pass filter is applied to eliminate DC bias from the input.
Wave shaping can introduce undesired digital aliasing in the output. Aliasing can be mitigated via oversampling. The following oversampling options are available
- Off (gray - default)
- x2 (yellow)
- x4 (green)
- x8 (light blue)
- x16 (dark blue)
- x32 (purple)
See Anti-aliasing via oversampling for more information.
The final output may optionally be hard clipped, or soft tanh clipped. There are 4 options.
- Off (gray)
- Hard +/- 5V (yellow - default)
- Soft +/- 5V (light blue)
- Soft +/- 6V (dark blue)
By default this button is disabled, and the main output is DC coupled, meaning the output may have a low frequency DC bias.
If this button is enabled, then the main output is AC coupled, meaning a high pass filter is applied to eliminate DC bias from the output.
Applies an offset to the main input before any wave shaping takes place.
The knob ranges from -5 to +5 volts. The attenuated input is summed with the knob value to get the effective offset.
The primary function is to offset unipolar main inputs to bipolar signals. But interesting effects can be had by applying dynamic CV modulation.
Applies an offset to the output after all wave shaping is complete (after output clipping, but before any output DC bias removal).
The knob ranges from -5 to +5 volts. The attenuated input is summed with the knob value to get the effective offset.
The primary function is to offset the bipolar main output to a unipolar signal.
The wave shaping is accomplished by independently computing high, mid, and low output components that get summed to create the final output.
Each value related to wave shaping has a value knob plus a CV input with attenuator.
Threshold knobs are bipolar with values ranging from -5 to +5 volts.
Amplifier knob values are bipolar with values ranging from -10x to +10x amplification.
Attenuated CV is summed with the corresponding knob value to get the effective value. The summed value is free to exceed the range of the knob.
Voltages above the High Threshold are considered the high region.
Voltages below the Low Threshold are considered the low region.
If the computed Low Threshold is above the computed High Threshold, then the values are internally swapped to ensure that the effective Low Threshold is never above the High Threshold.
Determines the amplification used for the middle output component. The main input is multiplied by the effective Mid Amplifier level to establish the middle output component.
The unlabeled small button determines whether the middle component is clipped at the high and low thresholds. It has 4 possible values:
- Off (dark gray) - No clipping is applied
- Pre amp (yellow, default) - The input is hard clipped at the high and low thresholds before applying the mid amplification.
- Post amp (blue) - The result of the mid amplifiction is hard clipped at the high and low thresholds.
- Pre and post amp (green) - The input is hard clipped at the high and low thresholds before applying the mid amplifcation, and then the result is hard clipped at the high and low thresholds.
If the Mid Amplifier is <= 1, then "Post amp" and "Pre and post amp" yield the same result.
If the Mid Amplifier is >= 1, then "Pre amp" and "Pre and post amp" yield the same result.
Determines the amplification used for the high output component.
If the input voltage is above the High Threshold, then the High Threshold is subtracted from the input before applying the high amplifier level to get the high output component.
If the input is not above the High Threshold, then the high output component is zero.
Determines the amplification used for the low output component.
If the input voltage is below the Low Threshold, then the Low Threshold is subtracted from the input before applying the low amplifier level to get the low output component.
If the input is not below the Low Threshold, then the low output component is zero.
This is the input signal to be wave shaped
This is the final wave shaped output that is the sum of the high, mid, and low output components.
All inputs and the output are fully polyphonic.
The number of poly channels in the output is the maximum channel count found across all inputs.
Monophonic inputs are replicated to match the output channel count.
Polyphonic inputs with fewer channels than the output are assigned constant 0V for the missing channels.
It can be difficult to decipher how the input is transformed into the final wave shaped output. Most users probably don't care and just twist knobs until the output is to their liking.
The summarized order of operations below is for those intrepid few that want to truly understand how the Wave Mangler works.
- All inputs are upsampled with interpolation if oversamping is enabled
- If In DC Block is enabled then the main Wave input is run through a high pass filter to remove DC bias
- Input Offset is applied to the main Wave input
- The mid output component is computed by multiplying the Wave input times the mid amplifier level. The mid component can optionally be clipped to the high and low thresholds before and/or after amplification.
- If the Wave input is > the High Threshold, then the (Wave input minus the High Threshold) is multiplied by the High amplifier level, else the high output component is zero.
- If the Wave input is < the Low Threshold, then the (Wave input minus the Low Threshold) is multiplied by the Low amplifier level, else the low ouptut component is zero.
- The mid, high, and low output components are summed to get the final wave shaped output.
- Any selected output clipping is applied to the wave shaped output
- Output Offset is applied to the wave shaped output
- If Out DC Block is enabled, then the wave shaped output is run through a high pass filter to remove DC bias from the output
- If oversampling is enabled then the output is passed through a band limiting low pass filter to remove high frequency output that would be aliased after downsampling, and then the output is downsampled
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If Wave Mangler is bypassed then all channels of the Wave input are passed through to the Wave output unchanged.
A polyphonic waveshaper inspired by the Doepfer A-137-2 Wave Multiplier II with integrated LFO modulation. Its primary use is to fatten the sound of simple wave forms like sine, triangle, and saw. It does not work well with square or pulse waves.
The Wave Multiplier works by mixing 4 copies of the incoming wave form with the original input. Each copy is compared to a different threshold, and if the current value is less than or equal to the threshold, then the value is shifted up as much as 5V. If greater than the threshold then the value is shifted down as much as 5V. If the input is a saw wave and the threshold is constant, then the net effect is a phase shift. If the input is a sine or triangle it is more like a fold operation. Applying modulation to the threshold adds movement to the sound.
The overall design is functionally very similar to the Doepfer module, with the following enhancements:
- Four bipolar triangle LFOs are added, with the outputs normalled to the shift threshold CV inputs to provide built in modulation.
- Rather than adjusting the input level, Depth controls and CV input are provided for the shift amount.
- The 8 internal outputs and 5 jumpers on the back of the Doepfer module are exposed as additional outputs and mutes on this Venom module.
- An option is added to remove DC offset from outputs.
- Level control and a VCA are provided for the final mix output.
- Oversampling options are provided to mitigate aliasing introduced by the digital implementation.
The Wave Multiplier default configuration is designed to produce pleasing fat sounds with lots of movement using only one input and one output. Patching the V/Oct CV used on the source input into the Wave Multiplier LFO V/Oct may yield more consistent results. Obviously more range is available by experimenting with the various controls and patching additional CV inputs.
The Wave Multiplier can be divided into three vertical sections
- Top LFO section
- Middle shift section
- Bottom Mix and I/O section
Sets the base frequency voltage of all four LFO oscillators using a volt per octave scale.
CV input for the base frequency voltage of all four oscillators. The CV is summed with the Master voltage.
Each knob sets an offset frequency voltage between -1 and 1 that is summed with the base frequency to establish the final LFO frequency. The knob defaults are uncorrelated, and range a bit over 1.5 octaves.
The +/-5V bipolar triangle LFO outputs
Controls the magnitude of the voltage shift that is applied to the four wave copies.
Supports audio rate modulation
Attenuates and/or inverts the Depth CV
Sets the base shift magnitude, ranging from 0 to 5 volts. The final attenuated CV is added to the knob value to establish the net shift magnitude.
Establishes the voltage threshold where the wave copy is either shifted up or down. Voltages above the threshold are shifted down, and voltages equal to or below the threshold are shifted up.
Allows modulation of the shift threshold via CV. Each input is normalled to the LFO output above. Supports audio rate modulation.
Attenuates and/or inverts the threshold CV.
Sets the base threshold voltage for shift operations. The base value is added to the attenuated CV value to get the net threshold.
The outputs for the four shift comparators. These are +/- 5V bipolar pulse waves. The shift depth controls are not applied to the pulse outputs.
Modulation to the shift thresholds produce pulse width modulation.
The outputs of the shifted waves. The pulse wave is attenuated by the depth control before being summed with the input wave copy to create the output shifted wave.
The main input, typically an audio signal.
Controls which of the shifted waves are included in the final output mix
Controls whether the raw input is included in the final output mix
10V corresponds to 100%. Audio rate modulation is supported. Negative values invert the output, so the VCA can function as a ring modulator.
Attenuates and/or inverts the level CV
Sets the base level amount (bias) between 0 and 100%. The base level is summed with the attenuated CV to establish the final output level.
The final output consisting of the mix of unmuted shifted waves and the unumuted input wave, attenuated by the Output Level.
If enabled, then DC offset will be removed from the Pulse, Shifted Wave, and Out outputs
Wave shifting and or audio rate level modulation can introduce undesireable inharmonic digital aliasing artifacts. Activating oversampling can mitigate those effects to yield a cleaner, more musical result.
See Anti-aliasing via oversampling for more information.
Wave Multiplier is fully polyphonic. In general, the number of output channels is computed as the maximum channel count found across all inputs.
Inputs that match the output polyphony behave as expected. Monophonic inputs are replicated to match the output polyphony count. Polyphonic inputs with fewer channels get constant 0V for any missing channels.
The LFOs are special. If the Master LFO V/Oct input is monophonic (or unpatched), then the LFO outputs are monophonic, regardless wether there are any polyphonic inputs elsewhere. But if the V/Oct is polyphonic, then the LFO output channel count matches the channel count for the rest of the module, and missing LFO V/Oct channels are treated as constant 0V.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If Wave Multiplier is bypassed, then all channels of the wave input are passed through unchanged to the shifted wave mix output. All other outputs are monophonic constant 0 volts.
Extend context menus to support parameter/port renaming and parameter custom defaults.
Custom names and defaults are stored with the patch and restored upon patch load as long as the Widget Menu Extender remains with the patch.
Factory names and defaults are restored whenever the Widget Menu Extender is removed from the patch.
Note that custom names and defaults are built into all of the Venom plugin modules (except for Rhythm Explorer). Widget Menu Extender brings that functionality to modules from foreign plugins (as well as Rhythm Explorer). The Venom module custom names and defaults are mainained independently from Widget Menu Extender.
Controls whether extended context menus are enabled or not. The button is bright blue when extended menus are On.
Extended context menu options will only be available if the Enable button is On.
Any existing custom names and defaults remain in effect when the extended menus are Off.
When enabled, the context menu for every foreign input port, output port, and parameter control is extended with an option to rename the parameter or port with a custom name. Once set, the custom name only appears in hover text and context menus - it does not update the module faceplate.
If a parameter or port has been given a custom name, then an additional menu option is added to restore the factory name.
If a module dynamically updates the parameter or port name, then that overrides any custom name from Widget Menu Extender.
Do not include "input" or "output" in your custom port name - VCV will automatically append input or output to the name you provide.
When enabled, the context menu for every foreign parameter control is extended with an option to set the default value to the current value. The parameter is set to the default value whenever it is initialized, whether by double click, or menu option, etc.
If a custom default value has been established, then an additional menu option is added to restore the factory default value.
If a module dynamically updates the parameter default value, then that overrides any custom default value from Widget Menu Extender.
Only one instance of Widget Menu Extender can be active per patch. If another instance is inserted, then it will be permanently disabled and the Enable button will be bright red. Since permanently disabled Widget Menu Extenders serve no purpose, they probably should be deleted from the patch.
If using VCV Pro within a DAW, each instance of the VCV plugin is regarded as a separate patch, and can have its own active Widget Menu Extender.
When importing a selection set containing Widget Menu Extender, custom names and defaults are preserved as long as the patch does not already have an active Widget Menu Extender. But if an active Widget Menu Extender already exists, then the selection set Widget Menu Extender will be permanently disabled, and selection set custom names and defaults will be lost.
When bypassed, Widget Menu Extender behaves the same as if the Enable button is off - the extended context menu options will not be available, but existing custom names and defaults are preserved.
A windowed polyphonic comparator inspired by the VCV Free COMPARE module, including the following enhancements:
- A tolerance factor to determine equivalency (the window)
- Options to rectify and/or invert signal outputs
- Gate output voltage options
- Additional gate outputs for A>=B and A<=B
- Oversampling options for audio applications
WINCOMP is fully polyphonic - the number of output channels is the maximum number of channels found across all three inputs. Monophonic inputs are replicated to match the number of output channels. Polyphonic inputs that have fewer channels use 0V for missing channels.
- A = A input, with OFFSET knob
- B = B input, with OFFSET knob
- TOL = Tolerance, with OFFSET knob. The tolerance specifies how close A must be to B in order to be considered equal.
Each input is summed with the corresponding OFFSET value. The OFFSETS are bipolar +/-10V. The resultant values are unconstrained.
The absolute value of TOL is used in all computations. The tolerance affects all outputs except MIN and MAX.
- MIN = Minimum output - the instantaneous minimum of the A and B inputs. TOL does not affect MIN.
- MAX = Maximum output - the instantaneous maximum of the A and B inputs. TOL does not affect MAX.
- CLAMP = A clamped to within B +/- TOL
- OVER = The overflow (positive or negative) from the CLAMP operation, computed as A - CLAMP.
Each of the signal output ports have context menu options to take the absolute value and or invert the output. The absolute value operation is performed prior to the inversion, so the output is guaranteed to be <=0V if both absolute value and invert are enabled.
A glowing green light in the lower left corner of the port indicates the output has the absolute value option enabled. A glowing red light in the lower right corner indicates the output has the invert option enabled.
- A=B = This gate is high if A is within B +/- TOL. OVER will be 0V when A=B is high. Computed as |A-B| <= |TOL|
- A<>B = This gate is high if A is not within B +/- TOL. OVER will be non-zero when A<>B is high. Computed as |A-B| > |TOL|
- A<=B = This gate is high if A is less than or equal to B +/- TOL. Computed as A <= B + |TOL|
- A>=B = This gate is high if A is greater than or equal to B +/- TOL. Computed as A >= B - |TOL|
- A<B = This gate is high if A is less than B +/- TOL. Computed as A < B - |TOL|
- A>B = This gate is high if A is greater than B +/- TOL. Computed as A > B + |TOL|
Each gate output has a small light in the lower right corner that glows yellow when the gate is high and the ouput is monophonic. The light glows blue if the output is polyphonic and at least one channel is high.
The gate high and low values are 0V and 10V by default. The module context menu includes an option to specify any of the following alternate values
- 0,1
- +/-1
- 0,5
- +/-5
- 0,10
- +/-10
By default WINCOMP is configured to output CV values, without any anti-aliasing. But if producing audio output, then the output may have unacceptable aliasing artifacts. The context menu has an option to enable oversampling to greatly reduce aliasing in audio outputs. The oversampling applies to all the outputs, including gate outputs.
Oversampling uses significant CPU, so there are multiple options to choose from: x2, x4, x8, and x16. The higher the oversample rate, the better the result, but more CPU is used.
There is also a context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
An LED glows blue above the output ports if oversampling is enabled. The LED is black when oversampling is off.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
All outputs are monophonic 0V if the module is bypassed.
A dual windowed comparator combined with logic operations inspired by the Joranalogue Compare 2 Eurorack module. The Venom module implements all the features of the Joranalogue hardware, and then adds:
- polyphony, all inputs and outputs are fully polyphonic
- options for gate output voltage levels
- tripled the number of outputs
- Joranalogue derives all outputs from whether an input is within the window
- Venom adds outputs for when the input is greater than the window, and less than the window.
- oversampling options to mitigate aliasing introduced by the digital implementation (obviously not needed for the analog Joranalogue module)
There are two identical comparators, each with an input plus controls and CV inputs to define a voltage window based on window center (shift) and window size. Each comparator produces gates for when the input voltage is either within the window (=), above the window (>), or below the window (<), as well as their negated values. Logic is then applied to the paired =, >, and < gate outputs using AND, OR, and XOR operations. The XOR outputs are then used to drive three Flip Flop outputs.
There is a Joranalogue Compare 2 Practical User Guide that shows a number of use cases for the Joranalogue hardware that also apply to Venom WinComp 2 + Logic. Of course the Venom module can do things that the Joranalogue module can't, but the practical guide is a good starting point.
Specifies the center of the comparator window. The knob value is summed with the CV input to establish the effective window center.
The Shift 2 CV input is normalled to the Shift 1 CV value.
Specifies the size of the comparator window. The knob value is summed with the CV input to establish the effective window size.
The Size 2 CV input is normalled to the Size 1 CV value.
The window maximum is simply the Shift value plus 1/2 the Size value, and the minimum is the Shift value minus 1/2 the Size value.
The IN inputs are the values that are compared against the comparator windows.
The IN 2 input is normalled to the IN 1 value.
Specifies the low and high values for all gate outputs. The following unipolar and bipolar values are available:
- 0-1V
- 0-5V
- 0-10V (default)
- +/- 1V
- +/- 5V
- +/- 10V
Specifies the amount of oversampling used to mitigate aliasing that can be introduced by the digital processing. This is generally only useful if working with relatively high frequency audio inputs.
- Off (default)
- x2
- x4
- x8
- x16
- x32
There is also a module context menu option to select the quality of the filters used for oversampling.
See Anti-aliasing via oversampling for more information.
Each comparator has three OUT outputs
- > - High when the input is above the window (> window max)
- = - High when the input is within the window (>= window min and <= window max)
- < - High when the input is below the window (< window min)
Note that if the effective window size is < 0, then the window max becomes lower than the window min, and = OUT can never be in a high state.
Each comparator has three NOT outputs
- > - High when the input is not above the window (<= window max)
- = - High when the input is not within the window (> window max or < window min)
- < - High when the input is not below the window (>= window min)
Each logic operation has three outputs
- > - High when both > OUT1 and > OUT2 are high, low when either is low
- = - High when both = OUT1 and = OUT2 are high, low when either is low
- < - High when both < OUT1 and < OUT1 are high, low when either is low
- > - High when either > OUT1 or > OUT2 is high, low when both are low
- = - High when either = OUT1 or = OUT2 is high, low when both are low
- < - High when either < OUT1 or < OUT2 is high, low when both are low
- > - High when > OUT1 and > OUT2 have different states, low when they are the same
- = - High when = OUT1 and = OUT2 have different states, low when they are the same
- < - High when < OUT1 and < OUT2 have different states, low when they are the same
- > - Changes state upon the leading edge of each high > XOR gate
- = - Changes state upon the leading edge of each high = XOR gate
- < - Changes state upon the leading edge of each high < XOR gate
All inputs and outputs are fully polyphonic. The number of output channels is the maximum number of input channels found across all inputs.
If an input is monophonic, then the single input channel is replicated to match the output channel count.
If an input has fewer channels then the outputs, then missing channels are assigned constant 0V.
Every gate output has an associated LED in the upper right corner that is off (dark gray) when the gate is low, and on (yellow) when the gate is high.
For polyphonic outputs, the default behavior is to set the LED brightness proportional to the percentage of channels in a high state.
There is a module context menu option to change which polyphonic channels are monitored.
- Off - all LEDS are permanently off (dark gray)
- All (default) - Each LED brightness is proportional to the percentage of channels in a high state.
- Single channel 1 through 16 - Only the specified channel is monitored
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If WinComp 2 + Logic is bypassed then all outputs are constant monophonic 0V.
Polyphonic synth voice with selectable waveform, modulation and feedback types (linear through-zero frequency, phase, ring, amplitude), and integer ratio frequencies.
XM-OP includes an ADSR (Attack, Decay, Sustain, Release) envelope generator, audio rate VCO, and VCA. The VCO output is always processed by the VCA.
XM-OP is very much inspired by the Bogaudio FM-OP, offering most of the same features, but with the following differences/enhancements:
- VCO waveform can be sine, triangle, square, or saw rather than being fixed at sine
- Envelope generator stage shape cross-fades between linear and curved rather having linear vs. exponential VCA response
- Rising curves are concave down and falling curves are convcave up instead of exponential rise and fall both being concave up
- Each ADSR stage has an attenuverter for a shared modulation input rather than only having CV control over sustain
- Attenuated CV values are summed with the base knob values
- Frequency ratio is specified by separate integer multiplier (numerator) and divisor (denominator) controls rather than a single continuous ratio control
- This is very conveninent for establishing a wide range of musical ratios
- The ratio multiplier, divisor, and detune can be CV controlled via three attenuverters with a shared CV input
- VCO external modulation and VCO feedback have selectable modulation types rather than being fixed at phase modulation
- Through zero linear frequency modulation (AC coupled)
- Phase modulation (called through zero linear FM by Bogaudio)
- Ring modulation
- Amplitude modulation with options
- raw modulation input
- rectified modulation input
- modulation input offset by 5V
- Envelope may be normal or inverted when applied to level, modulation depth, and/or feedback depth
- Level, mod depth, and feedback depth knob values (optionally attenuated by envelope) are summed with independent CV inputs with attenuverters
- The envelope (normal or inverted) is available as a separate output
- A configurable trigger input that can either sync the VCO, retrigger the envelope during decay or sustain, or both
Watch this Omri Cohen video for some lovely XM-OP voice examples that introduce many of module's features.
Selects the waveform for the VCO
- SIN (default) sine
- TRI triangle
- SQR square
- SAW
Selects the modulation mode used for the XMOD input
- FM (default) AC coupled linear through-zero frequency modulation
- PM Phase modulation
- RM Ring modulation - the waveform is multiplied by the XMOD using a 4 quadrant VCA
- AM Amplitude modulation - the waveform is multiplied by the XMOD using a 2 quadrant VCA, so negative XMOD values are treated as 0
- AM RECT Amplitude modulation with the XMOD fully rectified to positive values before multiplying
- AM OFF Amplitude modulation with the XMOD offset +5V before multiplying
Note that the RM and various AM assume the XMOD input is bipolar +/- 5V. The modulation is scaled such that the result is also bipolar +/- 5V (before hitting the VCA).
Selects the modulation type used for feedback. The options are the same as for the XMOD type.
Upon receipt of a high gate, the generator starts the attack stage and rises from 0% to 100% as long as the gate remains high. Once 100% is reached, it proceeds to the decay stage.
The decay stage falls from 100% to the sustain level as long as the gate remains high. Once the sustain level is reached it proceeds to the sustain stage.
The sustain stage maintains the sustain level as long as the gate remains high.
The envelope immediately jumps to the release stage whenever the gate goes low. This could happen during the attack, decay, or sustain stage. The release stage falls from the current value back to 0%.
The generator can be retriggered during the decay and release stages, in which case the attack stage is re-started from the current level instead of 0%.
Establishes the shape of the envelope attack, decay, and release stages. Fully counter-clockwise is linear, and fully clockwise has the most severe curvature. The knob is scaled to show the amount of curvature.
Curves are concave down for the attack phase, and concave up for the decay and release phases.
Changing the curvature does not change the stage times.
Establishes the time it takes the attack stage to rise from 0% to 100%. The knob range is 0.98 msec to 11.3 sec.
If the envelope is retriggered, then the attack stage can start above 0%, in which case the attack time is shortened proportionally.
Establishes the time it takes the decay stage to fall from 100% down to the sustain level. The knob range is 0.98 msec to 11.3 sec.
Establishes the level of the sustain stage. The knob range is 0% to 100%.
Establishes the time it takes the release stage to fall from the sustain level to 0%. The knob range is 0.98 msec to 11.3 sec.
If the gate goes low before the sustain stage is reached, then the release start level will not be the sustain level. If the release start is below the sustain level, then the release time will be decreased proportionally. If the release start is above the sustain level, then the release time will be for the release start down to 0%.
This is a shared input that can be used to modulate any of the envelope stages. Each stage has its own attenuverter to attenuate and/or invert the SMOD CV. The attenuated CV is summed with the knob value.
The attack, decay, and release stages scale the CV such that for each positive volt of CV, the time is doubled, and for each negative volt the time is halved. The stage times can be modulated beyond the knob values. The absolute minimum stage time is 0.24 msec, and the maximum is 181 seconds.
The sustain level CV is scaled at 10% per volt, and the effective sustain level is clamped between 0% and 100%.
XM-OP is intended to be used as a modulation operator, where one XM-OP modulates another. When performing modulation, the most musical results occur when there is an integral ratio relationship between the frequencies of the two operators. There are three controls to establish this ratio. XM-OP also has a V/Oct input where 0V always represents 261.63 Hz, or C4. There isn't any general tuning knob or octave knob. If there were, then it would disturb the ratio relationships.
Establishes the numerator of the frequency ratio. The knob is constrained to integral values from 1 to 64.
Establishes the denominator of the frequency ratio. The knob is constrained to integral values from 1 to 64.
Allows you to detune the ratio from the perfect integral ratio. The knob ranges from -100 cents to 100 cents.
This is a shared input that can be used to modulate any of the frequency ratio parameters. MULT, DIV, and DTUNE each have their own attenuverter to attenuate and/or invert the RMOD CV. The attenuated CV is summed with the knob value.
MULT and DIV CV are scaled at 1 integer per 0.1 volt. The effective MULT and DIV values are clamped between 1 and 64.
DTUNE CV is scaled at 10 cents per volt. The CV can modulate the detune amount beyond the knob limits.
The knob establishes the base level of the internal VCA output. It ranges from 0% to 100%.
Above the knob is a small ENV button that controls whether the VCA is attenuated by the internal envelope.
- Off (dark gray, default)
- On (yellow) The level is attenuated by the normal 0% - 100% envelope.
- Inverted (red) The level is attenuated by the inverted envelope that goes from 100% to 0%.
Below the knob is a CV input with associated attenuverter. The CV is scaled at 10% per volt. The attenuated CV is summed with the knob value (possibly attenuated by the envelope) to establish the final VCA level.
The knob establishes the depth of the XMOD modulation. It ranges from 0% to 100%. The type of modulation is controlled by the square XMOD button at the top.
Above the knob is a small ENV button that controls whether the depth is attenuated by the internal envelope.
- Off (dark gray, default)
- On (yellow) The depth is attenuated by the normal 0% - 100% envelope.
- Inverted (red) The depth is attenuated by the inverted envelope that goes from 100% to 0%.
Below the knob is a CV input with associated attenuverter. The CV is scaled at 10% per volt. The attenuated CV is summed with the knob value (possibly attenuated by the envelope) to establish the final depth value.
Note that for RM and AM modes, the depth cross fades between the raw unmodulated VCO at 0%, and the modulated VCO at 100%.
The knob establishes the depth of the feedback modulation. It ranges from 0% to 100%. The type of modulation is controlled by the square FDBK button at the top.
Above the knob is a small ENV button that controls whether the depth is attenuated by the internal envelope.
- Off (dark gray, default)
- On (yellow) The depth is attenuated by the normal 0% - 100% envelope.
- Inverted (red) The depth is attenuated by the inverted envelope that goes from 100% to 0%.
Below the knob is a CV input with associated attenuverter. The CV is scaled at 10% per volt. The attenuated CV is summed with the knob value (possibly attenuated by the envelope) to establish the final depth value.
Note that for RM and AM modes, the depth cross fades between the raw unmodulated VCO at 0%, and the modulated VCO at 100%.
Modulation can introduce unwanted inharmonic audio aliasing that can be mitigated by oversampling. The OVER button provides for the following oversampling levels
- Off (dark gray)
- x2 (yellow)
- x4 (green, default)
- x8 (light blue)
- x16 (dark blue)
- x32 (purple)
Note that only the XMOD input is upsampled to the oversample rate. The other inputs can be driven at audio rates, but they are not upsampled.
See Anti-aliasing via oversampling for more information.
The internal envelope is triggered on the leading edge of a gate. The envelope proceeds through the attack, decay, and sustain stages for as long as the gate remains high. The gate may also sync the VCO depending on how the SYNC/RTRG input is configured.
This trigger input has different behavior depending on the small mode button below the label
- VCO sync (blue, default) - The VCO is hard synced
- Envelope retrigger and VCO sync (green) - The envelope can be retriggered during the decay and sustain stages while the gate remains high, at which point the VCO is also hard synced. The gate input also hard syncs the VCO.
- Envelope retrigger, No VCO sync (yellow) - The envelope can be retriggered during the decay and sustain stages while the gate remains high.
Establishes the base frequency of the VCO before applying any frequency ratio, XMOD or feedback modulation. 0V represents 261.63 Hz, or C4.
This is the CV that modulates the VCO, with the type of modulation controled by the square XMOD button at the top. Typically audio signals are used.
The 0-10V envelope is output here. The mode of the output is controlled by the small button beside the label.
- Normal (dark gray, default) - The envelope starts at 0V and rises to 10V.
- Inverted (red) - The envelope is 10V at rest and falls to 0V during the attack stage.
The output of the VCA is output here. This is the modulated VCO output, after being attenuated by the VCA.
Venom Themes, Custom Names, and Parameter Locks and Custom Defaults are available via standard Venom context menus.
If XM-OP is bypassed then all outputs are constant monophonic 0V.