From 11931fea972a62bf310076279d44ea5271edaeb7 Mon Sep 17 00:00:00 2001 From: thomassidor Date: Wed, 23 Oct 2019 18:56:16 +0200 Subject: [PATCH] Fixed: Random Mix x8 (RX8) not working in trigger mode. --- README.md | 3 +++ plugin.json | 2 +- src/random-mix.cpp | 14 +++++++------- 3 files changed, 11 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index 798f042..e755a33 100644 --- a/README.md +++ b/README.md @@ -39,6 +39,9 @@ Thomas René Sidor ## Changelog +Version 1.2.1 +* Fixed: Random Mix x8 (RX8) not working in trigger mode. + Version 1.2.0 * Added: Random Mix x8 (RX8) * Added: Simplex Noise (SN1) diff --git a/plugin.json b/plugin.json index 0315711..56edf43 100644 --- a/plugin.json +++ b/plugin.json @@ -2,7 +2,7 @@ "slug": "TinyTricks", "name": "Tiny Tricks", "brand": "Tiny Tricks", - "version": "1.2.0", + "version": "1.2.1", "license": "MIT", "author": "Thomas René Sidor", "authorEmail": "mail@thomassidor.com", diff --git a/src/random-mix.cpp b/src/random-mix.cpp index af51d77..b27b0a2 100644 --- a/src/random-mix.cpp +++ b/src/random-mix.cpp @@ -61,11 +61,9 @@ struct RX8Base : Module { float t = 0.f; + float summedLevels = 0.f; void process(const ProcessArgs &args) override { - bool freeflow = (params[TRIGONLY_PARAM].getValue() == 0.f); - int connected = 0; - float summedLevels = 0.f; t += 1.0f / args.sampleRate; if(freeflow || (inputs[TRIG_INPUT].isConnected() && trigger.process(inputs[TRIG_INPUT].getVoltage()))){ @@ -90,12 +88,11 @@ struct RX8Base : Module { } //Getting new levels - float x = t; + summedLevels = 0.f; for (int i = 0; i < NUM_CHANNELS; i++) { if(inputs[AUDIO_L_INPUT + i].isConnected()){ - connected++; float y = (2.f*i); - float noiseVal = simp.SumOctave(jitter,x,y,0.7f,speed); + float noiseVal = simp.SumOctave(jitter,t,y,0.7f,speed); float level = clamp(noiseVal*(pinning),-1.f,1.f); level *= level; summedLevels += level; @@ -108,10 +105,13 @@ struct RX8Base : Module { //Mixing signal for output float mix = 0.f; + int connected = 0; if(outputs[MIX_L_OUTPUT].isConnected()){ for (int i = 0; i < NUM_CHANNELS; i++) { - if(inputs[AUDIO_L_INPUT + i].isConnected()) + if(inputs[AUDIO_L_INPUT + i].isConnected()) { + connected++; mix += inputs[AUDIO_L_INPUT + i].getVoltage()*levels[i]; + } } if(connected==1) outputs[MIX_L_OUTPUT].setVoltage(mix);