1 // generated from file '../src/LV2/faust/mbd.dsp' by dsp2cc:
2 // Code generated with Faust (https://faust.grame.fr)
3
4
5 namespace mbd {
6
7 class Dsp: public PluginLV2 {
8 private:
9 uint32_t fSampleRate;
10 int iVec0[2];
11 double fConst1;
12 double fConst2;
13 double fConst3;
14 FAUSTFLOAT fHslider0;
15 FAUSTFLOAT *fHslider0_;
16 double fRec4[2];
17 FAUSTFLOAT fHslider1;
18 FAUSTFLOAT *fHslider1_;
19 double fRec5[2];
20 FAUSTFLOAT fHslider2;
21 FAUSTFLOAT *fHslider2_;
22 double fRec11[2];
23 double fVec1[2];
24 double fRec10[2];
25 double fRec9[3];
26 FAUSTFLOAT fHslider3;
27 FAUSTFLOAT *fHslider3_;
28 double fRec8[3];
29 FAUSTFLOAT fHslider4;
30 FAUSTFLOAT *fHslider4_;
31 double fRec7[3];
32 FAUSTFLOAT fHslider5;
33 FAUSTFLOAT *fHslider5_;
34 double fRec6[3];
35 double fVec2[2];
36 double fConst4;
37 double fRec3[2];
38 double fRec0[2];
39 int iRec1[2];
40 double fRec2[2];
41 FAUSTFLOAT fVbargraph0;
42 FAUSTFLOAT *fVbargraph0_;
43 FAUSTFLOAT fHslider6;
44 FAUSTFLOAT *fHslider6_;
45 double fRec16[2];
46 FAUSTFLOAT fHslider7;
47 FAUSTFLOAT *fHslider7_;
48 double fRec17[2];
49 double fRec23[2];
50 double fRec22[3];
51 double fVec3[2];
52 double fRec21[2];
53 double fRec20[3];
54 double fRec19[3];
55 double fRec18[3];
56 double fVec4[2];
57 double fRec15[2];
58 double fRec12[2];
59 int iRec13[2];
60 double fRec14[2];
61 FAUSTFLOAT fVbargraph1;
62 FAUSTFLOAT *fVbargraph1_;
63 FAUSTFLOAT fHslider8;
64 FAUSTFLOAT *fHslider8_;
65 double fRec28[2];
66 FAUSTFLOAT fHslider9;
67 FAUSTFLOAT *fHslider9_;
68 double fRec29[2];
69 double fRec34[2];
70 double fRec33[3];
71 double fVec5[2];
72 double fRec32[2];
73 double fRec31[3];
74 double fRec30[3];
75 double fVec6[2];
76 double fRec27[2];
77 double fRec24[2];
78 int iRec25[2];
79 double fRec26[2];
80 FAUSTFLOAT fVbargraph2;
81 FAUSTFLOAT *fVbargraph2_;
82 FAUSTFLOAT fHslider10;
83 FAUSTFLOAT *fHslider10_;
84 double fRec39[2];
85 FAUSTFLOAT fHslider11;
86 FAUSTFLOAT *fHslider11_;
87 double fRec40[2];
88 double fRec44[2];
89 double fRec43[3];
90 double fVec7[2];
91 double fRec42[2];
92 double fRec41[3];
93 double fVec8[2];
94 double fRec38[2];
95 double fRec35[2];
96 int iRec36[2];
97 double fRec37[2];
98 FAUSTFLOAT fVbargraph3;
99 FAUSTFLOAT *fVbargraph3_;
100 FAUSTFLOAT fHslider12;
101 FAUSTFLOAT *fHslider12_;
102 double fRec49[2];
103 FAUSTFLOAT fHslider13;
104 FAUSTFLOAT *fHslider13_;
105 double fRec50[2];
106 double fRec52[2];
107 double fRec51[3];
108 double fVec9[2];
109 double fRec48[2];
110 double fRec45[2];
111 int iRec46[2];
112 double fRec47[2];
113 FAUSTFLOAT fVbargraph4;
114 FAUSTFLOAT *fVbargraph4_;
115 FAUSTFLOAT fVslider0;
116 FAUSTFLOAT *fVslider0_;
117 double fRec53[2];
118
119 void connect(uint32_t port,void* data);
120 void clear_state_f();
121 void init(uint32_t sample_rate);
122 void compute(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0);
123
124 static void clear_state_f_static(PluginLV2*);
125 static void init_static(uint32_t sample_rate, PluginLV2*);
126 static void compute_static(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0, PluginLV2*);
127 static void del_instance(PluginLV2 *p);
128 static void connect_static(uint32_t port,void* data, PluginLV2 *p);
129 public:
130 Dsp();
131 ~Dsp();
132 };
133
134
135
Dsp()136 Dsp::Dsp()
137 : PluginLV2() {
138 version = PLUGINLV2_VERSION;
139 id = "mbd";
140 name = N_("MultiBand Distortion");
141 mono_audio = compute_static;
142 stereo_audio = 0;
143 set_samplerate = init_static;
144 activate_plugin = 0;
145 connect_ports = connect_static;
146 clear_state = clear_state_f_static;
147 delete_instance = del_instance;
148 }
149
~Dsp()150 Dsp::~Dsp() {
151 }
152
clear_state_f()153 inline void Dsp::clear_state_f()
154 {
155 for (int l0 = 0; (l0 < 2); l0 = (l0 + 1)) iVec0[l0] = 0;
156 for (int l1 = 0; (l1 < 2); l1 = (l1 + 1)) fRec4[l1] = 0.0;
157 for (int l2 = 0; (l2 < 2); l2 = (l2 + 1)) fRec5[l2] = 0.0;
158 for (int l3 = 0; (l3 < 2); l3 = (l3 + 1)) fRec11[l3] = 0.0;
159 for (int l4 = 0; (l4 < 2); l4 = (l4 + 1)) fVec1[l4] = 0.0;
160 for (int l5 = 0; (l5 < 2); l5 = (l5 + 1)) fRec10[l5] = 0.0;
161 for (int l6 = 0; (l6 < 3); l6 = (l6 + 1)) fRec9[l6] = 0.0;
162 for (int l7 = 0; (l7 < 3); l7 = (l7 + 1)) fRec8[l7] = 0.0;
163 for (int l8 = 0; (l8 < 3); l8 = (l8 + 1)) fRec7[l8] = 0.0;
164 for (int l9 = 0; (l9 < 3); l9 = (l9 + 1)) fRec6[l9] = 0.0;
165 for (int l10 = 0; (l10 < 2); l10 = (l10 + 1)) fVec2[l10] = 0.0;
166 for (int l11 = 0; (l11 < 2); l11 = (l11 + 1)) fRec3[l11] = 0.0;
167 for (int l12 = 0; (l12 < 2); l12 = (l12 + 1)) fRec0[l12] = 0.0;
168 for (int l13 = 0; (l13 < 2); l13 = (l13 + 1)) iRec1[l13] = 0;
169 for (int l14 = 0; (l14 < 2); l14 = (l14 + 1)) fRec2[l14] = 0.0;
170 for (int l15 = 0; (l15 < 2); l15 = (l15 + 1)) fRec16[l15] = 0.0;
171 for (int l16 = 0; (l16 < 2); l16 = (l16 + 1)) fRec17[l16] = 0.0;
172 for (int l17 = 0; (l17 < 2); l17 = (l17 + 1)) fRec23[l17] = 0.0;
173 for (int l18 = 0; (l18 < 3); l18 = (l18 + 1)) fRec22[l18] = 0.0;
174 for (int l19 = 0; (l19 < 2); l19 = (l19 + 1)) fVec3[l19] = 0.0;
175 for (int l20 = 0; (l20 < 2); l20 = (l20 + 1)) fRec21[l20] = 0.0;
176 for (int l21 = 0; (l21 < 3); l21 = (l21 + 1)) fRec20[l21] = 0.0;
177 for (int l22 = 0; (l22 < 3); l22 = (l22 + 1)) fRec19[l22] = 0.0;
178 for (int l23 = 0; (l23 < 3); l23 = (l23 + 1)) fRec18[l23] = 0.0;
179 for (int l24 = 0; (l24 < 2); l24 = (l24 + 1)) fVec4[l24] = 0.0;
180 for (int l25 = 0; (l25 < 2); l25 = (l25 + 1)) fRec15[l25] = 0.0;
181 for (int l26 = 0; (l26 < 2); l26 = (l26 + 1)) fRec12[l26] = 0.0;
182 for (int l27 = 0; (l27 < 2); l27 = (l27 + 1)) iRec13[l27] = 0;
183 for (int l28 = 0; (l28 < 2); l28 = (l28 + 1)) fRec14[l28] = 0.0;
184 for (int l29 = 0; (l29 < 2); l29 = (l29 + 1)) fRec28[l29] = 0.0;
185 for (int l30 = 0; (l30 < 2); l30 = (l30 + 1)) fRec29[l30] = 0.0;
186 for (int l31 = 0; (l31 < 2); l31 = (l31 + 1)) fRec34[l31] = 0.0;
187 for (int l32 = 0; (l32 < 3); l32 = (l32 + 1)) fRec33[l32] = 0.0;
188 for (int l33 = 0; (l33 < 2); l33 = (l33 + 1)) fVec5[l33] = 0.0;
189 for (int l34 = 0; (l34 < 2); l34 = (l34 + 1)) fRec32[l34] = 0.0;
190 for (int l35 = 0; (l35 < 3); l35 = (l35 + 1)) fRec31[l35] = 0.0;
191 for (int l36 = 0; (l36 < 3); l36 = (l36 + 1)) fRec30[l36] = 0.0;
192 for (int l37 = 0; (l37 < 2); l37 = (l37 + 1)) fVec6[l37] = 0.0;
193 for (int l38 = 0; (l38 < 2); l38 = (l38 + 1)) fRec27[l38] = 0.0;
194 for (int l39 = 0; (l39 < 2); l39 = (l39 + 1)) fRec24[l39] = 0.0;
195 for (int l40 = 0; (l40 < 2); l40 = (l40 + 1)) iRec25[l40] = 0;
196 for (int l41 = 0; (l41 < 2); l41 = (l41 + 1)) fRec26[l41] = 0.0;
197 for (int l42 = 0; (l42 < 2); l42 = (l42 + 1)) fRec39[l42] = 0.0;
198 for (int l43 = 0; (l43 < 2); l43 = (l43 + 1)) fRec40[l43] = 0.0;
199 for (int l44 = 0; (l44 < 2); l44 = (l44 + 1)) fRec44[l44] = 0.0;
200 for (int l45 = 0; (l45 < 3); l45 = (l45 + 1)) fRec43[l45] = 0.0;
201 for (int l46 = 0; (l46 < 2); l46 = (l46 + 1)) fVec7[l46] = 0.0;
202 for (int l47 = 0; (l47 < 2); l47 = (l47 + 1)) fRec42[l47] = 0.0;
203 for (int l48 = 0; (l48 < 3); l48 = (l48 + 1)) fRec41[l48] = 0.0;
204 for (int l49 = 0; (l49 < 2); l49 = (l49 + 1)) fVec8[l49] = 0.0;
205 for (int l50 = 0; (l50 < 2); l50 = (l50 + 1)) fRec38[l50] = 0.0;
206 for (int l51 = 0; (l51 < 2); l51 = (l51 + 1)) fRec35[l51] = 0.0;
207 for (int l52 = 0; (l52 < 2); l52 = (l52 + 1)) iRec36[l52] = 0;
208 for (int l53 = 0; (l53 < 2); l53 = (l53 + 1)) fRec37[l53] = 0.0;
209 for (int l54 = 0; (l54 < 2); l54 = (l54 + 1)) fRec49[l54] = 0.0;
210 for (int l55 = 0; (l55 < 2); l55 = (l55 + 1)) fRec50[l55] = 0.0;
211 for (int l56 = 0; (l56 < 2); l56 = (l56 + 1)) fRec52[l56] = 0.0;
212 for (int l57 = 0; (l57 < 3); l57 = (l57 + 1)) fRec51[l57] = 0.0;
213 for (int l58 = 0; (l58 < 2); l58 = (l58 + 1)) fVec9[l58] = 0.0;
214 for (int l59 = 0; (l59 < 2); l59 = (l59 + 1)) fRec48[l59] = 0.0;
215 for (int l60 = 0; (l60 < 2); l60 = (l60 + 1)) fRec45[l60] = 0.0;
216 for (int l61 = 0; (l61 < 2); l61 = (l61 + 1)) iRec46[l61] = 0;
217 for (int l62 = 0; (l62 < 2); l62 = (l62 + 1)) fRec47[l62] = 0.0;
218 for (int l63 = 0; (l63 < 2); l63 = (l63 + 1)) fRec53[l63] = 0.0;
219 }
220
clear_state_f_static(PluginLV2 * p)221 void Dsp::clear_state_f_static(PluginLV2 *p)
222 {
223 static_cast<Dsp*>(p)->clear_state_f();
224 }
225
init(uint32_t sample_rate)226 inline void Dsp::init(uint32_t sample_rate)
227 {
228 fSampleRate = sample_rate;
229 double fConst0 = std::min<double>(192000.0, std::max<double>(1.0, double(fSampleRate)));
230 fConst1 = (1.0 / fConst0);
231 fConst2 = (3.1415926535897931 / fConst0);
232 fConst3 = (1.0 / (fConst2 + 1.0));
233 fConst4 = (1.0 - fConst2);
234 clear_state_f();
235 }
236
init_static(uint32_t sample_rate,PluginLV2 * p)237 void Dsp::init_static(uint32_t sample_rate, PluginLV2 *p)
238 {
239 static_cast<Dsp*>(p)->init(sample_rate);
240 }
241
compute(int count,FAUSTFLOAT * input0,FAUSTFLOAT * output0)242 void always_inline Dsp::compute(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0)
243 {
244 #define fHslider0 (*fHslider0_)
245 #define fHslider1 (*fHslider1_)
246 #define fHslider2 (*fHslider2_)
247 #define fHslider3 (*fHslider3_)
248 #define fHslider4 (*fHslider4_)
249 #define fHslider5 (*fHslider5_)
250 #define fVbargraph0 (*fVbargraph0_)
251 #define fHslider6 (*fHslider6_)
252 #define fHslider7 (*fHslider7_)
253 #define fVbargraph1 (*fVbargraph1_)
254 #define fHslider8 (*fHslider8_)
255 #define fHslider9 (*fHslider9_)
256 #define fVbargraph2 (*fVbargraph2_)
257 #define fHslider10 (*fHslider10_)
258 #define fHslider11 (*fHslider11_)
259 #define fVbargraph3 (*fVbargraph3_)
260 #define fHslider12 (*fHslider12_)
261 #define fHslider13 (*fHslider13_)
262 #define fVbargraph4 (*fVbargraph4_)
263 #define fVslider0 (*fVslider0_)
264 double fSlow0 = (0.0010000000000000009 * double(fHslider0));
265 double fSlow1 = (0.0010000000000000009 * double(fHslider1));
266 double fSlow2 = std::tan((fConst2 * double(fHslider2)));
267 double fSlow3 = (1.0 / fSlow2);
268 double fSlow4 = (((fSlow3 + 1.0000000000000004) / fSlow2) + 1.0);
269 double fSlow5 = (1.0 / fSlow4);
270 double fSlow6 = mydsp_faustpower2_f(fSlow2);
271 double fSlow7 = (1.0 / fSlow6);
272 double fSlow8 = (fSlow3 + 1.0);
273 double fSlow9 = (0.0 - (1.0 / (fSlow2 * fSlow8)));
274 double fSlow10 = (1.0 / fSlow8);
275 double fSlow11 = (1.0 - fSlow3);
276 double fSlow12 = (((fSlow3 + -1.0000000000000004) / fSlow2) + 1.0);
277 double fSlow13 = (2.0 * (1.0 - fSlow7));
278 double fSlow14 = (0.0 - (2.0 / fSlow6));
279 double fSlow15 = std::tan((fConst2 * double(fHslider3)));
280 double fSlow16 = (1.0 / fSlow15);
281 double fSlow17 = (fSlow16 + 1.0);
282 double fSlow18 = (1.0 / ((fSlow17 / fSlow15) + 1.0));
283 double fSlow19 = (1.0 - fSlow16);
284 double fSlow20 = (1.0 - (fSlow19 / fSlow15));
285 double fSlow21 = mydsp_faustpower2_f(fSlow15);
286 double fSlow22 = (1.0 / fSlow21);
287 double fSlow23 = (2.0 * (1.0 - fSlow22));
288 double fSlow24 = std::tan((fConst2 * double(fHslider4)));
289 double fSlow25 = (1.0 / fSlow24);
290 double fSlow26 = (fSlow25 + 1.0);
291 double fSlow27 = (1.0 / ((fSlow26 / fSlow24) + 1.0));
292 double fSlow28 = (1.0 - fSlow25);
293 double fSlow29 = (1.0 - (fSlow28 / fSlow24));
294 double fSlow30 = mydsp_faustpower2_f(fSlow24);
295 double fSlow31 = (1.0 / fSlow30);
296 double fSlow32 = (2.0 * (1.0 - fSlow31));
297 double fSlow33 = std::tan((fConst2 * double(fHslider5)));
298 double fSlow34 = (1.0 / fSlow33);
299 double fSlow35 = (fSlow34 + 1.0);
300 double fSlow36 = (1.0 / ((fSlow35 / fSlow33) + 1.0));
301 double fSlow37 = (1.0 - fSlow34);
302 double fSlow38 = (1.0 - (fSlow37 / fSlow33));
303 double fSlow39 = mydsp_faustpower2_f(fSlow33);
304 double fSlow40 = (1.0 / fSlow39);
305 double fSlow41 = (2.0 * (1.0 - fSlow40));
306 double fSlow42 = (0.0010000000000000009 * double(fHslider6));
307 double fSlow43 = (0.0010000000000000009 * double(fHslider7));
308 double fSlow44 = (((fSlow16 + 1.0000000000000004) / fSlow15) + 1.0);
309 double fSlow45 = (1.0 / fSlow44);
310 double fSlow46 = (0.0 - (1.0 / (fSlow15 * fSlow17)));
311 double fSlow47 = (1.0 / fSlow17);
312 double fSlow48 = (1.0 / (fSlow15 * fSlow4));
313 double fSlow49 = (((fSlow16 + -1.0000000000000004) / fSlow15) + 1.0);
314 double fSlow50 = (0.0 - (2.0 / fSlow21));
315 double fSlow51 = (0.0010000000000000009 * double(fHslider8));
316 double fSlow52 = (0.0010000000000000009 * double(fHslider9));
317 double fSlow53 = (((fSlow25 + 1.0000000000000004) / fSlow24) + 1.0);
318 double fSlow54 = (1.0 / fSlow53);
319 double fSlow55 = (0.0 - (1.0 / (fSlow24 * fSlow26)));
320 double fSlow56 = (1.0 / fSlow26);
321 double fSlow57 = (1.0 / (fSlow24 * fSlow44));
322 double fSlow58 = (((fSlow25 + -1.0000000000000004) / fSlow24) + 1.0);
323 double fSlow59 = (0.0 - (2.0 / fSlow30));
324 double fSlow60 = (0.0010000000000000009 * double(fHslider10));
325 double fSlow61 = (1.0 / (((fSlow34 + 1.0000000000000004) / fSlow33) + 1.0));
326 double fSlow62 = (0.0010000000000000009 * double(fHslider11));
327 double fSlow63 = (0.0 - (1.0 / (fSlow33 * fSlow35)));
328 double fSlow64 = (1.0 / fSlow35);
329 double fSlow65 = (1.0 / (fSlow33 * fSlow53));
330 double fSlow66 = (((fSlow34 + -1.0000000000000004) / fSlow33) + 1.0);
331 double fSlow67 = (0.0 - (2.0 / fSlow39));
332 double fSlow68 = (0.0010000000000000009 * double(fHslider12));
333 double fSlow69 = (0.0010000000000000009 * double(fHslider13));
334 double fSlow70 = (0.0010000000000000009 * std::pow(10.0, (0.050000000000000003 * double(fVslider0))));
335 for (int i0 = 0; (i0 < count); i0 = (i0 + 1)) {
336 iVec0[0] = 1;
337 int iTemp0 = (iRec1[1] < 4096);
338 fRec4[0] = (fSlow0 + (0.999 * fRec4[1]));
339 fRec5[0] = (fSlow1 + (0.999 * fRec5[1]));
340 fRec11[0] = ((9.9999999999999995e-21 * double((1 - iVec0[1]))) - fRec11[1]);
341 double fTemp1 = (double(input0[i0]) + fRec11[0]);
342 fVec1[0] = fTemp1;
343 fRec10[0] = ((fSlow9 * fVec1[1]) - (fSlow10 * ((fSlow11 * fRec10[1]) - (fSlow3 * fTemp1))));
344 fRec9[0] = (fRec10[0] - (fSlow5 * ((fSlow12 * fRec9[2]) + (fSlow13 * fRec9[1]))));
345 double fTemp2 = (fSlow23 * fRec8[1]);
346 fRec8[0] = ((fSlow5 * (((fSlow7 * fRec9[0]) + (fSlow14 * fRec9[1])) + (fSlow7 * fRec9[2]))) - (fSlow18 * ((fSlow20 * fRec8[2]) + fTemp2)));
347 double fTemp3 = (fSlow32 * fRec7[1]);
348 fRec7[0] = ((fRec8[2] + (fSlow18 * (fTemp2 + (fSlow20 * fRec8[0])))) - (fSlow27 * ((fSlow29 * fRec7[2]) + fTemp3)));
349 double fTemp4 = (fSlow41 * fRec6[1]);
350 fRec6[0] = ((fRec7[2] + (fSlow27 * (fTemp3 + (fSlow29 * fRec7[0])))) - (fSlow36 * ((fSlow38 * fRec6[2]) + fTemp4)));
351 double fTemp5 = std::max<double>(-1.0, std::min<double>(1.0, (fRec4[0] + (std::pow(10.0, (2.0 * fRec5[0])) * (fRec6[2] + (fSlow36 * (fTemp4 + (fSlow38 * fRec6[0]))))))));
352 double fTemp6 = (fTemp5 * (1.0 - (0.33333333333333331 * mydsp_faustpower2_f(fTemp5))));
353 fVec2[0] = fTemp6;
354 fRec3[0] = (fConst3 * ((fTemp6 - fVec2[1]) + (fConst4 * fRec3[1])));
355 double fTemp7 = std::max<double>(fConst1, std::fabs(fRec3[0]));
356 double fElse0 = std::max<double>(fRec0[1], fTemp7);
357 fRec0[0] = (iTemp0 ? fElse0 : fTemp7);
358 int iElse1 = (iRec1[1] + 1);
359 iRec1[0] = (iTemp0 ? iElse1 : 1);
360 fRec2[0] = (iTemp0 ? fRec2[1] : fRec0[1]);
361 fVbargraph0 = FAUSTFLOAT(fRec2[0]);
362 int iTemp8 = (iRec13[1] < 4096);
363 fRec16[0] = (fSlow42 + (0.999 * fRec16[1]));
364 fRec17[0] = (fSlow43 + (0.999 * fRec17[1]));
365 fRec23[0] = (0.0 - (fSlow10 * ((fSlow11 * fRec23[1]) - (fTemp1 + fVec1[1]))));
366 fRec22[0] = (fRec23[0] - (fSlow5 * ((fSlow12 * fRec22[2]) + (fSlow13 * fRec22[1]))));
367 double fTemp9 = (fRec22[2] + (fRec22[0] + (2.0 * fRec22[1])));
368 double fTemp10 = (fSlow5 * fTemp9);
369 fVec3[0] = fTemp10;
370 fRec21[0] = ((fSlow46 * fVec3[1]) - (fSlow47 * ((fSlow19 * fRec21[1]) - (fSlow48 * fTemp9))));
371 fRec20[0] = (fRec21[0] - (fSlow45 * ((fSlow49 * fRec20[2]) + (fSlow23 * fRec20[1]))));
372 double fTemp11 = (fSlow32 * fRec19[1]);
373 fRec19[0] = ((fSlow45 * (((fSlow22 * fRec20[0]) + (fSlow50 * fRec20[1])) + (fSlow22 * fRec20[2]))) - (fSlow27 * ((fSlow29 * fRec19[2]) + fTemp11)));
374 double fTemp12 = (fSlow41 * fRec18[1]);
375 fRec18[0] = ((fRec19[2] + (fSlow27 * (fTemp11 + (fSlow29 * fRec19[0])))) - (fSlow36 * ((fSlow38 * fRec18[2]) + fTemp12)));
376 double fTemp13 = std::max<double>(-1.0, std::min<double>(1.0, (fRec16[0] + (std::pow(10.0, (2.0 * fRec17[0])) * (fRec18[2] + (fSlow36 * (fTemp12 + (fSlow38 * fRec18[0]))))))));
377 double fTemp14 = (fTemp13 * (1.0 - (0.33333333333333331 * mydsp_faustpower2_f(fTemp13))));
378 fVec4[0] = fTemp14;
379 fRec15[0] = (fConst3 * ((fTemp14 - fVec4[1]) + (fConst4 * fRec15[1])));
380 double fTemp15 = std::max<double>(fConst1, std::fabs(fRec15[0]));
381 double fElse3 = std::max<double>(fRec12[1], fTemp15);
382 fRec12[0] = (iTemp8 ? fElse3 : fTemp15);
383 int iElse4 = (iRec13[1] + 1);
384 iRec13[0] = (iTemp8 ? iElse4 : 1);
385 fRec14[0] = (iTemp8 ? fRec14[1] : fRec12[1]);
386 fVbargraph1 = FAUSTFLOAT(fRec14[0]);
387 int iTemp16 = (iRec25[1] < 4096);
388 fRec28[0] = (fSlow51 + (0.999 * fRec28[1]));
389 fRec29[0] = (fSlow52 + (0.999 * fRec29[1]));
390 fRec34[0] = (0.0 - (fSlow47 * ((fSlow19 * fRec34[1]) - (fTemp10 + fVec3[1]))));
391 fRec33[0] = (fRec34[0] - (fSlow45 * ((fSlow49 * fRec33[2]) + (fSlow23 * fRec33[1]))));
392 double fTemp17 = (fRec33[2] + (fRec33[0] + (2.0 * fRec33[1])));
393 double fTemp18 = (fSlow45 * fTemp17);
394 fVec5[0] = fTemp18;
395 fRec32[0] = ((fSlow55 * fVec5[1]) - (fSlow56 * ((fSlow28 * fRec32[1]) - (fSlow57 * fTemp17))));
396 fRec31[0] = (fRec32[0] - (fSlow54 * ((fSlow58 * fRec31[2]) + (fSlow32 * fRec31[1]))));
397 double fTemp19 = (fSlow41 * fRec30[1]);
398 fRec30[0] = ((fSlow54 * (((fSlow31 * fRec31[0]) + (fSlow59 * fRec31[1])) + (fSlow31 * fRec31[2]))) - (fSlow36 * ((fSlow38 * fRec30[2]) + fTemp19)));
399 double fTemp20 = std::max<double>(-1.0, std::min<double>(1.0, (fRec28[0] + (std::pow(10.0, (2.0 * fRec29[0])) * (fRec30[2] + (fSlow36 * (fTemp19 + (fSlow38 * fRec30[0]))))))));
400 double fTemp21 = (fTemp20 * (1.0 - (0.33333333333333331 * mydsp_faustpower2_f(fTemp20))));
401 fVec6[0] = fTemp21;
402 fRec27[0] = (fConst3 * ((fTemp21 - fVec6[1]) + (fConst4 * fRec27[1])));
403 double fTemp22 = std::max<double>(fConst1, std::fabs(fRec27[0]));
404 double fElse6 = std::max<double>(fRec24[1], fTemp22);
405 fRec24[0] = (iTemp16 ? fElse6 : fTemp22);
406 int iElse7 = (iRec25[1] + 1);
407 iRec25[0] = (iTemp16 ? iElse7 : 1);
408 fRec26[0] = (iTemp16 ? fRec26[1] : fRec24[1]);
409 fVbargraph2 = FAUSTFLOAT(fRec26[0]);
410 int iTemp23 = (iRec36[1] < 4096);
411 fRec39[0] = (fSlow60 + (0.999 * fRec39[1]));
412 fRec40[0] = (fSlow62 + (0.999 * fRec40[1]));
413 fRec44[0] = (0.0 - (fSlow56 * ((fSlow28 * fRec44[1]) - (fTemp18 + fVec5[1]))));
414 fRec43[0] = (fRec44[0] - (fSlow54 * ((fSlow58 * fRec43[2]) + (fSlow32 * fRec43[1]))));
415 double fTemp24 = (fRec43[2] + (fRec43[0] + (2.0 * fRec43[1])));
416 double fTemp25 = (fSlow54 * fTemp24);
417 fVec7[0] = fTemp25;
418 fRec42[0] = ((fSlow63 * fVec7[1]) - (fSlow64 * ((fSlow37 * fRec42[1]) - (fSlow65 * fTemp24))));
419 fRec41[0] = (fRec42[0] - (fSlow61 * ((fSlow66 * fRec41[2]) + (fSlow41 * fRec41[1]))));
420 double fTemp26 = std::max<double>(-1.0, std::min<double>(1.0, (fRec39[0] + (fSlow61 * (std::pow(10.0, (2.0 * fRec40[0])) * (((fSlow40 * fRec41[0]) + (fSlow67 * fRec41[1])) + (fSlow40 * fRec41[2])))))));
421 double fTemp27 = (fTemp26 * (1.0 - (0.33333333333333331 * mydsp_faustpower2_f(fTemp26))));
422 fVec8[0] = fTemp27;
423 fRec38[0] = (fConst3 * ((fTemp27 - fVec8[1]) + (fConst4 * fRec38[1])));
424 double fTemp28 = std::max<double>(fConst1, std::fabs(fRec38[0]));
425 double fElse9 = std::max<double>(fRec35[1], fTemp28);
426 fRec35[0] = (iTemp23 ? fElse9 : fTemp28);
427 int iElse10 = (iRec36[1] + 1);
428 iRec36[0] = (iTemp23 ? iElse10 : 1);
429 fRec37[0] = (iTemp23 ? fRec37[1] : fRec35[1]);
430 fVbargraph3 = FAUSTFLOAT(fRec37[0]);
431 int iTemp29 = (iRec46[1] < 4096);
432 fRec49[0] = (fSlow68 + (0.999 * fRec49[1]));
433 fRec50[0] = (fSlow69 + (0.999 * fRec50[1]));
434 fRec52[0] = (0.0 - (fSlow64 * ((fSlow37 * fRec52[1]) - (fTemp25 + fVec7[1]))));
435 fRec51[0] = (fRec52[0] - (fSlow61 * ((fSlow66 * fRec51[2]) + (fSlow41 * fRec51[1]))));
436 double fTemp30 = std::max<double>(-1.0, std::min<double>(1.0, (fRec49[0] + (fSlow61 * (std::pow(10.0, (2.0 * fRec50[0])) * (fRec51[2] + (fRec51[0] + (2.0 * fRec51[1]))))))));
437 double fTemp31 = (fTemp30 * (1.0 - (0.33333333333333331 * mydsp_faustpower2_f(fTemp30))));
438 fVec9[0] = fTemp31;
439 fRec48[0] = (fConst3 * ((fTemp31 - fVec9[1]) + (fConst4 * fRec48[1])));
440 double fTemp32 = std::max<double>(fConst1, std::fabs(fRec48[0]));
441 double fElse12 = std::max<double>(fRec45[1], fTemp32);
442 fRec45[0] = (iTemp29 ? fElse12 : fTemp32);
443 int iElse13 = (iRec46[1] + 1);
444 iRec46[0] = (iTemp29 ? iElse13 : 1);
445 fRec47[0] = (iTemp29 ? fRec47[1] : fRec45[1]);
446 fVbargraph4 = FAUSTFLOAT(fRec47[0]);
447 fRec53[0] = (fSlow70 + (0.999 * fRec53[1]));
448 output0[i0] = FAUSTFLOAT((((((fRec3[0] + fRec15[0]) + fRec27[0]) + fRec38[0]) + fRec48[0]) * fRec53[0]));
449 iVec0[1] = iVec0[0];
450 fRec4[1] = fRec4[0];
451 fRec5[1] = fRec5[0];
452 fRec11[1] = fRec11[0];
453 fVec1[1] = fVec1[0];
454 fRec10[1] = fRec10[0];
455 fRec9[2] = fRec9[1];
456 fRec9[1] = fRec9[0];
457 fRec8[2] = fRec8[1];
458 fRec8[1] = fRec8[0];
459 fRec7[2] = fRec7[1];
460 fRec7[1] = fRec7[0];
461 fRec6[2] = fRec6[1];
462 fRec6[1] = fRec6[0];
463 fVec2[1] = fVec2[0];
464 fRec3[1] = fRec3[0];
465 fRec0[1] = fRec0[0];
466 iRec1[1] = iRec1[0];
467 fRec2[1] = fRec2[0];
468 fRec16[1] = fRec16[0];
469 fRec17[1] = fRec17[0];
470 fRec23[1] = fRec23[0];
471 fRec22[2] = fRec22[1];
472 fRec22[1] = fRec22[0];
473 fVec3[1] = fVec3[0];
474 fRec21[1] = fRec21[0];
475 fRec20[2] = fRec20[1];
476 fRec20[1] = fRec20[0];
477 fRec19[2] = fRec19[1];
478 fRec19[1] = fRec19[0];
479 fRec18[2] = fRec18[1];
480 fRec18[1] = fRec18[0];
481 fVec4[1] = fVec4[0];
482 fRec15[1] = fRec15[0];
483 fRec12[1] = fRec12[0];
484 iRec13[1] = iRec13[0];
485 fRec14[1] = fRec14[0];
486 fRec28[1] = fRec28[0];
487 fRec29[1] = fRec29[0];
488 fRec34[1] = fRec34[0];
489 fRec33[2] = fRec33[1];
490 fRec33[1] = fRec33[0];
491 fVec5[1] = fVec5[0];
492 fRec32[1] = fRec32[0];
493 fRec31[2] = fRec31[1];
494 fRec31[1] = fRec31[0];
495 fRec30[2] = fRec30[1];
496 fRec30[1] = fRec30[0];
497 fVec6[1] = fVec6[0];
498 fRec27[1] = fRec27[0];
499 fRec24[1] = fRec24[0];
500 iRec25[1] = iRec25[0];
501 fRec26[1] = fRec26[0];
502 fRec39[1] = fRec39[0];
503 fRec40[1] = fRec40[0];
504 fRec44[1] = fRec44[0];
505 fRec43[2] = fRec43[1];
506 fRec43[1] = fRec43[0];
507 fVec7[1] = fVec7[0];
508 fRec42[1] = fRec42[0];
509 fRec41[2] = fRec41[1];
510 fRec41[1] = fRec41[0];
511 fVec8[1] = fVec8[0];
512 fRec38[1] = fRec38[0];
513 fRec35[1] = fRec35[0];
514 iRec36[1] = iRec36[0];
515 fRec37[1] = fRec37[0];
516 fRec49[1] = fRec49[0];
517 fRec50[1] = fRec50[0];
518 fRec52[1] = fRec52[0];
519 fRec51[2] = fRec51[1];
520 fRec51[1] = fRec51[0];
521 fVec9[1] = fVec9[0];
522 fRec48[1] = fRec48[0];
523 fRec45[1] = fRec45[0];
524 iRec46[1] = iRec46[0];
525 fRec47[1] = fRec47[0];
526 fRec53[1] = fRec53[0];
527 }
528 #undef fHslider0
529 #undef fHslider1
530 #undef fHslider2
531 #undef fHslider3
532 #undef fHslider4
533 #undef fHslider5
534 #undef fVbargraph0
535 #undef fHslider6
536 #undef fHslider7
537 #undef fVbargraph1
538 #undef fHslider8
539 #undef fHslider9
540 #undef fVbargraph2
541 #undef fHslider10
542 #undef fHslider11
543 #undef fVbargraph3
544 #undef fHslider12
545 #undef fHslider13
546 #undef fVbargraph4
547 #undef fVslider0
548 }
549
compute_static(int count,FAUSTFLOAT * input0,FAUSTFLOAT * output0,PluginLV2 * p)550 void __rt_func Dsp::compute_static(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0, PluginLV2 *p)
551 {
552 static_cast<Dsp*>(p)->compute(count, input0, output0);
553 }
554
555
connect(uint32_t port,void * data)556 void Dsp::connect(uint32_t port,void* data)
557 {
558 switch ((PortIndex)port)
559 {
560 case DRIVE1:
561 fHslider13_ = (float*)data; // , 0.0, 0.0, 1.0, 0.01
562 break;
563 case DRIVE2:
564 fHslider11_ = (float*)data; // , 0.0, 0.0, 1.0, 0.01
565 break;
566 case DRIVE3:
567 fHslider9_ = (float*)data; // , 0.0, 0.0, 1.0, 0.01
568 break;
569 case DRIVE4:
570 fHslider7_ = (float*)data; // , 0.0, 0.0, 1.0, 0.01
571 break;
572 case DRIVE5:
573 fHslider1_ = (float*)data; // , 0.0, 0.0, 1.0, 0.01
574 break;
575 case GAIN:
576 fVslider0_ = (float*)data; // , 0.0, -40.0, 4.0, 0.10000000000000001
577 break;
578 case OFFSET1:
579 fHslider12_ = (float*)data; // , 0.0, 0.0, 0.5, 0.01
580 break;
581 case OFFSET2:
582 fHslider10_ = (float*)data; // , 0.0, 0.0, 0.5, 0.01
583 break;
584 case OFFSET3:
585 fHslider8_ = (float*)data; // , 0.0, 0.0, 0.5, 0.01
586 break;
587 case OFFSET4:
588 fHslider6_ = (float*)data; // , 0.0, 0.0, 0.5, 0.01
589 break;
590 case OFFSET5:
591 fHslider0_ = (float*)data; // , 0.0, 0.0, 0.5, 0.01
592 break;
593 case CROSSOVER_B1_B2:
594 fHslider5_ = (float*)data; // , 80.0, 20.0, 20000.0, 1.0800000000000001
595 break;
596 case CROSSOVER_B2_B3:
597 fHslider4_ = (float*)data; // , 210.0, 20.0, 20000.0, 1.0800000000000001
598 break;
599 case CROSSOVER_B3_B4:
600 fHslider3_ = (float*)data; // , 1700.0, 20.0, 20000.0, 1.0800000000000001
601 break;
602 case CROSSOVER_B4_B5:
603 fHslider2_ = (float*)data; // , 5000.0, 20.0, 20000.0, 1.0800000000000001
604 break;
605 case V1:
606 fVbargraph4_ = (float*)data; // , 0, -70.0, 5.0, 0
607 break;
608 case V2:
609 fVbargraph3_ = (float*)data; // , 0, -70.0, 5.0, 0
610 break;
611 case V3:
612 fVbargraph2_ = (float*)data; // , 0, -70.0, 5.0, 0
613 break;
614 case V4:
615 fVbargraph1_ = (float*)data; // , 0, -70.0, 5.0, 0
616 break;
617 case V5:
618 fVbargraph0_ = (float*)data; // , 0, -70.0, 5.0, 0
619 break;
620 default:
621 break;
622 }
623 }
624
connect_static(uint32_t port,void * data,PluginLV2 * p)625 void Dsp::connect_static(uint32_t port,void* data, PluginLV2 *p)
626 {
627 static_cast<Dsp*>(p)->connect(port, data);
628 }
629
630
plugin()631 PluginLV2 *plugin() {
632 return new Dsp();
633 }
634
del_instance(PluginLV2 * p)635 void Dsp::del_instance(PluginLV2 *p)
636 {
637 delete static_cast<Dsp*>(p);
638 }
639
640 /*
641 typedef enum
642 {
643 DRIVE1,
644 DRIVE2,
645 DRIVE3,
646 DRIVE4,
647 DRIVE5,
648 GAIN,
649 OFFSET1,
650 OFFSET2,
651 OFFSET3,
652 OFFSET4,
653 OFFSET5,
654 CROSSOVER_B1_B2,
655 CROSSOVER_B2_B3,
656 CROSSOVER_B3_B4,
657 CROSSOVER_B4_B5,
658 V1,
659 V2,
660 V3,
661 V4,
662 V5,
663 } PortIndex;
664 */
665
666 } // end namespace mbd
667