Update: 2020-08-18

IterativeSinCluster is an additive synthesizer. This synth computes 512 sine waves for each note to make tone cluster. I somehow thought “iterative sin” is a valid term. Correct term is “recursive sine”.
IterativeSinCluster requires CPU which supports AVX or later SIMD instructions.
The package includes following builds:
macOS build isn’t tested because I don’t have Mac. If you found a bug, please file a issue to GitHub repository or send email to ryukau@gmail.com.
Linux build is built on Ubuntu 18.0.4 and tested on Bitwig and Reaper. If you are using distribution other than Ubuntu 18.04, plugin will not likely run. In this case, please take a look at build instruction.
Place *.vst3 directory to:
/Program Files/Common Files/VST3/ for Windows.$HOME/.vst3/ for Linux./Users/$USERNAME/Library/Audio/Plug-ins/VST3/ for macOS.DAW may provides additional VST3 directory. For more information, please refer to the manual of the DAW.
Extract preset zip, then place preset directory to the OS specific path:
/Users/$USERNAME/Documents/VST3 Presets/Uhhyou$HOME/.vst3/presets/Uhhyou/Users/$USERNAME/Library/Audio/Presets/UhhyouPreset directory name must be the same as the plugin. Make Uhhyou directory if it does not exist.
If DAW doesn’t recognize the plugin, try installing C++ redistributable (vc_redist.x64.exe). Installer can be found in the link below.
On Ubuntu 18.0.4, those packages are required.
If DAW doesn’t recognize the plugin, take a look at Package Requirements section of the link below and make sure all the VST3 related package is installed.
REAPER on Linux may not recognize the plugin. A workaround is to delete a file ~/.config/REAPER/reaper-vstplugins64.ini and restart REAPER.
When trying to run plugin first time, following message may appear on macOS.
<PluginName>.vst3 is damaged and can't be opened. You should move it to
the Trash"
In this case, open terminal and try running following command to unzipped .vst3 directory.
Plugin may be considered as unsigned/un-notarized application. In this case, try following the steps below.
sudo spctl --master-disable.Beware that steps above degrades security of your system. To revert the settings, follow the steps below.
sudo spctl --master-enable.At first time, create color config file to:
/Users/USERNAME/AppData/Roaming/UhhyouPlugins/style/style.json on Windows.$XDG_CONFIG_HOME/UhhyouPlugins/style/style.json on Linux.
$XDG_CONFIG_HOME is empty, make $HOME/.config/UhhyouPlugins/style/style.json./Users/$USERNAME/Library/Preferences/UhhyouPlugins/style/style.json on macOS.Below is a example of style.json.
{
"fontPath": "",
"foreground": "#000000",
"foregroundButtonOn": "#000000",
"foregroundInactive": "#8a8a8a",
"background": "#ffffff",
"boxBackground": "#ffffff",
"border": "#000000",
"borderCheckbox": "#000000",
"borderLabel": "#000000",
"unfocused": "#dddddd",
"highlightMain": "#0ba4f1",
"highlightAccent": "#13c136",
"highlightButton": "#fcc04f",
"highlightWarning": "#fc8080",
"overlay": "#00000088",
"overlayHighlight": "#00ff0033"
}Hex color codes are used.
First letter # is conventional. Plugins ignore the first letter of color code, thus ?102938, \n11335577 are valid.
Do not use characters outside of 0-9a-f for color value.
fontPath: Absolute path to *.ttf font file. Not implemented in VST 3 version.foreground: Text color.foregroundButtonOn: Text color of active toggle button. Recommend to use the same value of foreground or boxBackground.foregroundInactive: Text color of inactive components. Currently, only used for TabView.background: Background color.boxBackground: Background color of inside of box shaped components (Barbox, Button, Checkbox, OptionMenu, TextKnob, VSlider).border: Border color of box shaped components.borderCheckbox: Border color of CheckBox.borderLabel: Line color of parameter section label.unfocused: Color to fill unfocused components. Currently, only used for knobs.highlightMain: Color to indicate focus is on a component. Highlight colors are also used for value of slider components (BarBox and VSlider).highlightAccent: Same as highlightMain. Used for cosmetics.highlightButton: Color to indicate focus is on a button.highlightWarning: Same as highlightMain, but only used for parameters which requires extra caution.overlay: Overlay color. Used to overlay texts and indicators.overlayHighlight: Overlay color to highlight current focus.Knob and slider can do:
Additionally, number sliders use in Gain, Semi etc. can do:
Overtone has following controls:
If the image is small, use Ctrl + Mouse Wheel or “View Image” on right click menu to scale.
Diagram only shows overview. It’s not exact implementation.
Both controls output gain. Peak value of output will be Boost * Gain.
It’s possible that output gain becomes too small while changing gain of Note, Chord, Overtone. Boost can be useful in this situation.
Parameters for gain envelope.
A : Attack time which is the length from note-on to reaching peak value.D : Decay time which is the length from peak value to reaching sustain level.S : Sustain level which is the gain after decay.R : Release time which is the length from note-off to the gain reaching to 0.Change attack curve of gain envelope.
Cutoff freqeuncy can be changed by Semi, which is relative to a note frequency. For example, if the note is C4 and Semi is 12.000, cutoff frequency is set to C4 + 12 semitone = C5.
Low shelving changes Gain of sine waves less than or equal to the cutoff frequency specified by Semi.High shelving changes Gain of sine waves greater than or equal to the cutoff frequency specified by Semi.When checked, the synth enables rendering of sine waves over nyquist frequency.
Roughly speaking, nyquist frequency is the highest frequency that can be reconstructed from recorded digital signal. When generating sound, it’s possible to set value that is higher than nyquist frequency. However, the result may contain unexpected frequency due to a phenomenon called aliasing. Add Aliasing is option to add those aliasing noise.
When checked, negate sign of Semi. For example, 7.000 becomes -7.000.
Note octave.
ET stands for equal temperament. This parameter can be used to change tuning of Semi and Milli.
Note that this parameter is not to change tuning of notes sent from plugin host. Only affect to internal parameters.
Change sine wave frequency.
Equation is noteFrequency * (1 + fmod(Multiply * pitch, Modulo)). pitch is calculated from Note, Chord and Overtone. fmod(a, b) is a function that returns reminder of a / b.
Time length to change some parameter value to current one. Unit is in second.
List of parameters related to Smooth. * represents wild card.
Gain section.Chord.PanChorus section, except Key Follow.Other parameter uses the value obtained from the timing of note-on for entire duration of a note.
Maximum polyphony. Lowering the number of this option reduces CPU load.
When checked, reset random seed for each note-on.
Random seed. This value change random number sequence.
Amount of randomization to sine wave gain. Randomization is done for each note-on.
Amount of randomization to sine wave pitch. Randomization is done for each note-on.
Change sine wave gain and pitch.
1 Note have 16 Overtone. 1 Chord consists of 8 Note. 4 Chord are available to use.
Common parameters for Note and Chord.
Gain : Sine wave gain.Semi : Distance from note frequency. Unit is semitone.Milli : Distance from note frequency. Unit is 1 / 1000 semitone, or 1 / 10 cent.Leftmost of Overtone is gain of fundamental frequency (1st overtone) of a note. For each bar from left represents 1st, 2nd, 3rd, … , 16th overtone gain.
Below is the summary of calculation of sine wave frequency.
function toneToPitch(semi, milli):
return 2 ^ (1000 * semi + milli) / (ET * 1000)
for each Chord:
chordPitch = toneToPitch(Chord.semi, Chord.milli)
for each Note:
notePitch = toneToPitch(Note.semi, Note.milli)
for each Overtone:
frequency = midiNoteFrequency
* (1 + mod(Multiply * Overtone * notePitch * chordPitch, Modulo))
Change Dry/Wet mix ratio.
Chorus LFO frequency.
Change stereo spread.
Amount of modulation from LFO to delay time. There are three delays in this chorus.
Delay time.
LFO phase.
Phase difference between delays.
Feedback of delay.
When checked, change delay time relative to note frequency.
IterativeSinCluster is licensed under GPLv3. Complete licenses are linked below.
If the link above doesn’t work, please send email to ryukau@gmail.com.
VST is a trademark of Steinberg Media Technologies GmbH, registered in Europe and other countries.