-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathFoldBack.cpp
executable file
·103 lines (64 loc) · 2.3 KB
/
FoldBack.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
//**************************************************************************************
//FoldBack Distortion Module for VCV Rack by Autodafe http://www.autodafe.net
//
//Based on code taken from the Fundamentals plugins by Andrew Belt http://www.vcvrack.com
//And part of code on musicdsp.org: http://musicdsp.org/showArchiveComment.php?ArchiveID=203
//**************************************************************************************
#include "Autodafe.hpp"
struct FoldBack : Module {
enum ParamIds {
THRESHOLD_PARAM,
ATTEN_PARAM,
NUM_PARAMS
};
enum InputIds {
INPUT,
CV_THRESHOLD,
NUM_INPUTS
};
enum OutputIds {
OUTPUT,
NUM_OUTPUTS
};
FoldBack();
void step();
};
FoldBack::FoldBack() {
params.resize(NUM_PARAMS);
inputs.resize(NUM_INPUTS);
outputs.resize(NUM_OUTPUTS);
}
float foldback(float in, float threshold)
{
if (in>threshold || in<-threshold)
{
in = fabs(fabs(fmod(in - threshold, threshold * 4)) - threshold * 2) - threshold;
}
return in;
}
void FoldBack::step() {
float in = inputs[INPUT].value / 5.0;
float threshold = params[THRESHOLD_PARAM].value;
float coeff = inputs[CV_THRESHOLD].value * params[ATTEN_PARAM].value / 5.0;
outputs[OUTPUT].value= 5.0* foldback(in, threshold+coeff);
}
FoldBackWidget::FoldBackWidget() {
FoldBack *module = new FoldBack();
setModule(module);
box.size = Vec(15 * 6, 380);
{
SVGPanel *panel = new SVGPanel();
panel->box.size = box.size;
panel->setBackground(SVG::load(assetPlugin(plugin, "res/FoldBack.svg")));
addChild(panel);
}
addChild(createScrew<ScrewSilver>(Vec(5, 0)));
addChild(createScrew<ScrewSilver>(Vec(box.size.x - 20, 0)));
addChild(createScrew<ScrewSilver>(Vec(5, 365)));
addChild(createScrew<ScrewSilver>(Vec(box.size.x - 20, 365)));
addParam(createParam<AutodafeKnobGreenBig>(Vec(18, 61), module, FoldBack::THRESHOLD_PARAM, 0.1, 1.0, 1.0));
addInput(createInput<PJ301MPort>(Vec(32, 150), module, FoldBack::CV_THRESHOLD));
addParam(createParam<AutodafeKnobGreen>(Vec(27, 190), module, FoldBack::ATTEN_PARAM, -1.0, 1.0, 0.0));
addInput(createInput<PJ301MPort>(Vec(10, 320), module, FoldBack::INPUT));
addOutput(createOutput<PJ301MPort>(Vec(48, 320), module, FoldBack::OUTPUT));
}