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