A semi-modular polyphonic synthesizer plugin with different oscillator and effect types,
AM+FM osc-to-osc routing matrices and both global and per-voice audio and cv routing matrices.
There is also an fx version which routes external input instead of voice output to the global effect section.
It's fully resizable by scaling (by dragging the bottom right corner) and also reacts to system DPI settings.
A knob with a circle in it or a slider with a small dot in it means it can be modulated by the CV matrices.
Hover over a parameter to see a more detailed description.
By default the UI shows the realtime state of the audio engine for both graphs and parameters.
Since this is quite CPU expensive (sorry i didn't do fancy gpu offloading) there's an option to back down
on the amount of realtime repainting, see Visuals dropdown in the master section.
- Parameter modulation global or single active voice paints the exact audio engine state.
- Parameter modulation multiple active voices paints the minimum and maximum values across all active voices.
- Graph modulation global or single active voice paints the exact audio engine state.
- Graph modulation multiple active voices paints the most recent voice state.
- Graph modulation zero active voices paints the static automation state.
- Drag any parameter that can act as a mod source (Aux N, Mod Wheel etc) by dragging the parameter label
- Drag any parameter that can act as a mod target (Osc Gain, Filter Freq etc) by dragging the parameter label
- Drag any module that can act as a mod source (Global LFO N, Envelope N etc) by dragging the tab header
- Drag any module that can act as an audio route source or target (Osc N, Voice FX N, Voice Out, Master Out etc) by dragging the tab header
- For a modulatable parameter that is itself inside one of the mod matrices, drag that parameter by dragging the small dot left of it, to another mod matrix
When dragging, the following indicators show whether the dragged item can be dropped onto a matrix route source/target:
- No indicator means nothing can be dropped here
- [ N/A ] means the dragged item can never be dropped here
- [ OK ] means the dragged item can be dropped here. Release the mouse to apply.
- [ X ] means the dragged item can not currently be dropped here because it would result in invalid routing.
There's a couple of built-in themes. If you want to customize, look for the themes folder in the plugin bundle.
You can either edit an existing theme or just copy-paste a theme folder and edit that, and it will get picked up.
Stuff you can override per-section: various colors and graph background images.
Stuff you can override globally: title image, font (bring your own TTF), font size,
various corner radii and element sizes and plugin size and aspect ratio.
- Right-click a parameter to show the host menu.
- Right-click some empty space to show the undo/redo menu.
- Right-click a matrix header to show clear/tidy matrix options.
- Right-click a module header to show copy/clear/swap etc options.
- Right-click the first column in a matrix to show matrix manipulation options.
- Most parameters can be automated
- Most continuous-valued parameters can be automated per sample
- Most continuous-valued parameters can be modulated per sample. This includes both internal modulation through the mod matrices and host modulation by the CLAP bindings.
- Some global discrete-valued parameters can be automated per block
- Most per-voice discrete-valued parameters can be automated "at voice start"
Processing order is global cv -> voice cv -> voice audio -> global audio.
This means that you can use only global cv sources to modulate global audio,
and you can use any cv source to modulate per-voice audio.
For cv-to-cv modulation, the processing order matters:
- MIDI
- Master In
- Global LFO
- Note/On-Note
- Envelope
- Voice LFO
This means that you can modulate for example global lfo by master in, but not the other way around.
Similarly, you can can modulate voice-lfo by f.e. global lfo or voice envelope, but not envelope by voice-lfo.
Within a single module you can only modulate upwards, for example env1->env2 or lfo1->lfo2, but not lfo2->lfo1.
- Ffpreset files are shareable between CLAP and VST3.
- VST3: does sample accurate automation, no note expressions.
- CLAP: does sample accurate automation, does threadpool, does global modulation, no polyphonic modulation.
Comes with 2 monophonic modes: true mono ("Mono") and release-monophonic mode ("Release").
Monophonic mode has all kinds of opportunities to introduce pops and clicks. To combat that:
- Use portamento to get rid of sudden pitch changes.
- Use multi-triggered envelopes instead of retriggered envelopes to prevent sudden jumps in the envelope (or just go with legato).
Furthermore, true monophonic mode may often not do what you want. Release-monophonic mode is much more easily understood as a series of independent monophonic sections (which may overlap in their envelope release section, hence, not "true monophonic").
Firefly features 3 random mod sources for each voice. These can be selected in the per-voice mod-matrices as "On Note->On Nt Rnd N". In this case each mod source will be a static/fixed value determined at the start of each voice.
These 3 random values can also be used as seed-values for per-voice random LFOs (smooth 2/(free)-static 2). When used in this way it essentially allows you to draw a complete new random stream for each voice. This is especially useful when playing chords: although each note kicks in at the exact same sample position (assuming host data, not external midi), each of these notes/voices can use 3 entirely different random lfos. So 9 streams for a 3-note chord.
It is also possible to select a used-defined seed value for per-voice LFO's in (smooth 1/(free)-static 1), in which case the modulation source is deterministic (even if random). However in this case each note in a chord will follow the exact same "random" pattern.
Firefly features basic microtuning support. "Basic" meaning it's microtuning features pertain to the oscillators only. There's no support for tuning effect types (Comb Filter/SV Filter/SV Filter inside distortion).
Microtuning is implemented by Firefly acting as an MTS-ESP client (https://github.com/ODDSound/MTS-ESP). Firefly cannot load tuning scales on it's own, so you will need an MTS-ESP Master plugin such as https://oddsound.com/mtsespsuite.php to use it. Microtuning support is enabled by default, but it will only take effect once an MTS-ESP master plugin is loaded into the project. In which case, the MTS-ESP indicator will show as active in the monitor section.
On the front panel (alongside Patch/Preset/Theme select) there's a Tuning menu that allows 5 options. Please note that Tuning Mode is saved with the plugin instance as a whole, and it is not part of the patch.
- No Tuning - if an MTS-ESP Master is loaded into the DAW, ignore it.
- On Note Before Modulation (Default) - fix the tuning at voice start and retune before modulation.
- On Note After Modulation - fix the tuning at voice start and retune after modulation.
- Continuous Before Modulation - keep retuning for the lifetime of the voice, and retune before modulation.
- Continuous After Modulation - keep retuning for the lifetime of the voice, and retune after modulation.
"Before Mod" probably does what you want when playing the same MIDI notes against multiple tuned plugins. "After Mod" is the way to go when you expect "play C3 against an oscillator set to C5" to produce the same results as "play C5 against an oscillator set to C3". After-mod also takes all pitch modulators (cents, unison detuning, raw pitch etc) into account. For monophonic mode, on-note really means on-voice-start. If you want note-by-note retuning for monophonic, continuous is the way to go.
Builds up a note table from the current chord, then loops through that table outputting 1 or more notes on each round. To explain, see below for what happens when playing c-major (let's say C4-E4-G4).
- Type: selects the octave count. C4-E4-G4 with +1 octave then becomes C4-E4-G4-C5-E5-G5.
- Mode: rearranges the table after octave selection. F.e. "down" just reverses it, for up-down it becomes C4-E4-G4-C5-E5-G5-E5-C5-G4-E4.
- Jump: rearranges the table after mode selection. When on, table becomes first-next-first-next etc. In this example, C4-E4-C4-G4-C4-C5-C4-E5-C4-G5-C4-E5-C4-C5-C4-G4-C4-E4.
- Flip: rearranges the table after jumping by inverting note selection every N positions. In this example with flip set to 2: C4-E4-G4-C4-C4-C5-E5-C4-C4-G5-E5-C4-C4-C5-G4-C4-C4-E4.
There are 4 random modes which allow to either reset or free-run on table construction (happens on note-on/off) and table repeat.
- Notes: select this many notes to output from the table. If table is C4-E4-G4-C5-E5-G5 (with distance set to 1), consecutive outputs are C4+E4, E4+G4, G4+C5, C5+E5, E5+G5, G5+C4, repeat.
- Distance: distance between multiple notes in the table. If table is C4-E4-G4-C5-E5-G5 (with distance set to 2), consecutive outputs are C4+G4, E4+C5, G4+E5, C5+G5, E5+C4, G5+E4, repeat.
If you set the note count exactly equal to the table size with distance equal to 1 (f.e. input chord = ceg, type = plain, mode = up) the arpeggiator will just be repeating the input chord. Combined with the rate modulator this may be used as a very crude sort-of pattern generator.
- Sync: controls output rate type (in hz or bars)
- Rate: selects output rate
When the internal LFO modulator is off, that's all there's to it. Otherwise:
- Mod mode: selects off/linear/exponential modulation.
- Mod: selects the internal LFO shape which is used to modulate the output rate.
- Amount: selects how much to change the output rate relative to the base rate.
When synced, (output rate + modulator offset) is snapped to the base rate. F.e. 1/4 with linear slowdown gets you 1/4, 2/4, 3/4, exponential slowdown gets 1/4, 1/2, 1/1. 1/4 with linear speedup gets you (1/4)/1, (1/4)/2, (1/4)/3, exponential speedup gets 1/4, 1/8, 1/16.
These are probably best used as on-note versions, but regular versions are available, too.
- Note absolute: with a table of C4-B4-C5 this gets you 0.0, 0.5, 1.0.
- Note relative: with a table of C4-B4-C5 this gets you (0/12), (11/12), (12/12).
- Table absolute position: with a table size of 5 this gets you 0.0, 0.25, 0.5, 0.75, 1.0.
- Table relative position: takes flipping into account. F.e. with flip set to 2, gets you 0.0, 0.25, 0.75, 0.5, 1.0.
- Single start-y value + max 16 segments
- Per-segment width, y, and slope controls
- Inline visual editor + resizable popup-editor
- Visual editor with snap-to-grid support (see below)
- Automation and per-voice-start modulation of all width, y and slope params
- For envelopes, set mode to MSEG. For LFO's, toggle the MSEG switch.
MSEG segments are defined as a single start-y value + N (segment count) times width+y+slope parameters. Width parameters are relative to each other with bounds (1, 100). For example an MSEG curve with widths (1, 2, 4) will result in relative segment sizes of (1/7, 2/7, 4/7). When snap-x is off, segment widths are automatable and modulatable. When snap-x is on, all segments have equal size. Segment Y and slope are always automatable/modulatable. Automation/modulation is per-voice-start (envelope/VLFO) or per-block (GLFO).
The MSEG as a whole can be either set to absolute time or synced to project tempo (bars). When set to time, the total MSEG time is modulatable.
For LFO's: MSEGs react to step count, smoothing and phase adjustment, but not X/Y skewing.
For envelopes, you can set 1 point as a sustain point. In DAHDSR terms, this means that "all the rest" is considered to be the release section. Retrigger/multitrigger and follow/release envelope types are also implemented by considering all segments after the sustain point as a single "release" section.
- Double-click an existing point to delete it.
- Double-click elsewhere to insert a new point.
- Right-click for context menu.
- Per-point context menu: host controls for width/y/slope, and set point as sustain point.
- Editor context menu: allows to control snap-x and snap-y values and open/close external editor.
- Drag points around to define the curve. Slopes and Y points are always draggable. Width is only draggable when snap-x is off.
- External editor is resizable and synced with inline editor.
- Right-click or ESC to close external editor.
Snap-Y is really just a visiual helper. It allows you to vertically divide the grid into N sections and when dragging points it will snap the vertical position onto the grid. Slopes are not snapped. However automation/modulation of point vertical positions is still possible, but it will not take snapping into account.
Snap-X (when on) forces all segments to be equal width. Unlike snap-y, when snap-x is on, this really does affect how the audio engine works. When on, all segments are equal width, and automation/modulation of the segment widths is NOT possible.
See the parameter reference document for details.
- Arpeggiator.
- MSEG envelopes.
- Microtuning support.
- Envelope 1 hardwired to voice gain.
- Per-voice and global audio routing matrices.
- Per-voice and global cv-to-cv routing matrices.
- Per-voice and global cv-to-audio routing matrices.
- On-note versions of all global modulation sources.
- Oscillator-to-oscillator AM and FM routing matrices.
- Pitchbend and modwheel linked to external MIDI input.
- Portamento with tempo syncing and regular/automatic glide mode.
- Responds to MIDI pitchbend, modwheel and all 128 CC parameters.
- Monitor module with active voice count, cpu and threadpool usage.
- Modulation visualization for graphs (lfo, envelope, cv matrix) and parameters.
- Smoothing controls for parameter automation, MIDI input and host BPM changes.
- Up to 64 voices in polyphonic mode. Global unison voices also count towards this limit.
- Global unison with pitch, lfo and envelope detuning, stereo spread and osc/lfo phase offset.
- Per-voice DAHDSR envelopes with tempo syncing, linear and exponential slopes and 3 envelope modes.
- Per-voice and global LFO's with tempo syncing, one-shot mode, various waveforms and horizontal and vertical skewing.
- Per-voice random as mod source + per-voice random mod source as seed-value for per-voice random lfo generators.
- Per-voice and global FX modules with state variable filter, comb filter, distortion, multiband eq and (global only) reverb, feedback- and multitap delay.
- Oscillators with classic waveforms, DSF synthesis, 2 Karplus-Strong modes, noise generator, unison and hard-sync, pitch and phase modulation.