1 // generated from file '../src/plugins/bmp.dsp' by dsp2cc:
2 // Code generated with Faust (https://faust.grame.fr)
3
4 #include "gx_faust_support.h"
5 #include "gx_plugin.h"
6 #include "clipping.h"
7
8 namespace pluginlib {
9 namespace bmp {
10
11 class Dsp: public PluginDef {
12 private:
13 gx_resample::FixedRateResampler smp;
14 int sample_rate;
15 int fSampleRate;
16 double fConst0;
17 double fConst1;
18 double fConst4;
19 double fConst6;
20 double fConst8;
21 double fConst10;
22 double fConst12;
23 double fConst13;
24 double fConst14;
25 double fConst15;
26 double fRec4[3];
27 FAUSTFLOAT fVslider0;
28 double fRec5[2];
29 double fConst17;
30 double fConst19;
31 double fConst21;
32 double fConst22;
33 double fConst23;
34 double fConst24;
35 double fRec3[3];
36 double fConst26;
37 double fConst28;
38 double fConst29;
39 double fConst30;
40 double fConst31;
41 double fConst32;
42 double fRec2[3];
43 double fConst33;
44 double fConst34;
45 double fConst36;
46 double fConst37;
47 double fRec1[3];
48 double fConst38;
49 double fConst39;
50 FAUSTFLOAT fVslider1;
51 double fRec6[2];
52 double fConst40;
53 double fConst41;
54 double fConst42;
55 double fConst43;
56 double fRec0[3];
57 FAUSTFLOAT fVslider2;
58 double fRec7[2];
59
60 void clear_state_f();
61 int load_ui_f(const UiBuilder& b, int form);
62 static const char *glade_def;
63 void init(unsigned int sample_rate);
64 void compute(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0);
65 int register_par(const ParamReg& reg);
66
67 static void clear_state_f_static(PluginDef*);
68 static int load_ui_f_static(const UiBuilder& b, int form);
69 static void init_static(unsigned int sample_rate, PluginDef*);
70 static void compute_static(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0, PluginDef*);
71 static int register_params_static(const ParamReg& reg);
72 static void del_instance(PluginDef *p);
73 public:
74 Dsp();
75 ~Dsp();
76 };
77
78
79
Dsp()80 Dsp::Dsp()
81 : PluginDef() {
82 version = PLUGINDEF_VERSION;
83 flags = 0;
84 id = "bmp";
85 name = N_("BigMuffPi");
86 groups = 0;
87 description = N_("BigMuffPi"); // description (tooltip)
88 category = N_("Fuzz"); // category
89 shortname = N_("BMP"); // shortname
90 mono_audio = compute_static;
91 stereo_audio = 0;
92 set_samplerate = init_static;
93 activate_plugin = 0;
94 register_params = register_params_static;
95 load_ui = load_ui_f_static;
96 clear_state = clear_state_f_static;
97 delete_instance = del_instance;
98 }
99
~Dsp()100 Dsp::~Dsp() {
101 }
102
clear_state_f()103 inline void Dsp::clear_state_f()
104 {
105 for (int l0 = 0; (l0 < 3); l0 = (l0 + 1)) fRec4[l0] = 0.0;
106 for (int l1 = 0; (l1 < 2); l1 = (l1 + 1)) fRec5[l1] = 0.0;
107 for (int l2 = 0; (l2 < 3); l2 = (l2 + 1)) fRec3[l2] = 0.0;
108 for (int l3 = 0; (l3 < 3); l3 = (l3 + 1)) fRec2[l3] = 0.0;
109 for (int l4 = 0; (l4 < 3); l4 = (l4 + 1)) fRec1[l4] = 0.0;
110 for (int l5 = 0; (l5 < 2); l5 = (l5 + 1)) fRec6[l5] = 0.0;
111 for (int l6 = 0; (l6 < 3); l6 = (l6 + 1)) fRec0[l6] = 0.0;
112 for (int l7 = 0; (l7 < 2); l7 = (l7 + 1)) fRec7[l7] = 0.0;
113 }
114
clear_state_f_static(PluginDef * p)115 void Dsp::clear_state_f_static(PluginDef *p)
116 {
117 static_cast<Dsp*>(p)->clear_state_f();
118 }
119
init(unsigned int RsamplingFreq)120 inline void Dsp::init(unsigned int RsamplingFreq)
121 {
122 sample_rate = 96000;
123 smp.setup(RsamplingFreq, sample_rate);
124 fSampleRate = sample_rate;
125 fConst0 = std::min<double>(192000.0, std::max<double>(1.0, double(fSampleRate)));
126 fConst1 = mydsp_faustpower2_f(fConst0);
127 double fConst2 = (4.3388468105506801e-10 * fConst0);
128 double fConst3 = ((fConst0 * (fConst2 + 6.8680901344593704e-09)) + 2.6522670215943701e-08);
129 fConst4 = (fConst1 / fConst3);
130 double fConst5 = (3.6868885846545499e-10 * fConst0);
131 fConst6 = (1.0 / ((fConst0 * (fConst5 + 3.0348555108869402e-06)) + 0.00486780557301784));
132 double fConst7 = (3.9204879585950002e-10 * fConst0);
133 fConst8 = (1.0 / ((fConst0 * (fConst7 + 2.0047872746271098e-06)) + 0.00048978515761155495));
134 double fConst9 = (7.6673121439986096e-12 * fConst0);
135 fConst10 = (fConst0 * (fConst9 + -3.9949085717896201e-05));
136 double fConst11 = (2.0828770493449602e-05 * fConst0);
137 fConst12 = (1.0 / (fConst11 + 0.00021901631427173599));
138 fConst13 = (3.7454979802541999e-06 * fConst0);
139 fConst14 = (0.0 - fConst13);
140 fConst15 = (0.00021901631427173599 - fConst11);
141 double fConst16 = (1.2821120020392999e-10 * fConst0);
142 fConst17 = (fConst16 + -6.2652181541007596e-07);
143 double fConst18 = (1.12312054615984e-09 * fConst0);
144 fConst19 = (fConst18 + -2.8621970465474001e-06);
145 double fConst20 = (1.1344651981412601e-09 * fConst0);
146 fConst21 = (2.8911081278256599e-06 - fConst20);
147 fConst22 = (fConst16 + 6.2652181541007596e-07);
148 fConst23 = (fConst18 + 2.8621970465474001e-06);
149 fConst24 = (-2.8911081278256599e-06 - fConst20);
150 double fConst25 = (2.26293387153501e-14 * fConst0);
151 fConst26 = (fConst25 + -1.17905906929765e-07);
152 double fConst27 = (2.26293387153501e-12 * fConst0);
153 fConst28 = (fConst27 + -1.17905906929765e-05);
154 fConst29 = (fConst25 + 1.17905906929765e-07);
155 fConst30 = (fConst27 + 1.17905906929765e-05);
156 fConst31 = (0.00097957031522311099 - (7.8409759171899901e-10 * fConst1));
157 fConst32 = ((fConst0 * (fConst7 + -2.0047872746271098e-06)) + 0.00048978515761155495);
158 fConst33 = (0.0 - (1.53346242879972e-11 * fConst1));
159 fConst34 = (fConst0 * (fConst9 + 3.9949085717896201e-05));
160 double fConst35 = (7.3737771693091102e-10 * fConst1);
161 fConst36 = (0.0097356111460356904 - fConst35);
162 fConst37 = ((fConst0 * (fConst5 + -3.0348555108869402e-06)) + 0.00486780557301784);
163 fConst38 = (8.6710157453912601e-07 * fConst0);
164 fConst39 = ((3.6868885846545499e-10 * fConst1) + -0.0031609127097518498);
165 fConst40 = (-0.0063218254195036901 - fConst35);
166 fConst41 = (1.0 / fConst3);
167 fConst42 = (5.3045340431887401e-08 - (8.6776936211013499e-10 * fConst1));
168 fConst43 = ((fConst0 * (fConst2 + -6.8680901344593704e-09)) + 2.6522670215943701e-08);
169 clear_state_f();
170 }
171
init_static(unsigned int sample_rate,PluginDef * p)172 void Dsp::init_static(unsigned int sample_rate, PluginDef *p)
173 {
174 static_cast<Dsp*>(p)->init(sample_rate);
175 }
176
compute(int count,FAUSTFLOAT * input0,FAUSTFLOAT * output0)177 void always_inline Dsp::compute(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0)
178 {
179 FAUSTFLOAT buf[smp.max_out_count(count)];
180 int ReCount = smp.up(count, input0, buf);
181 double fSlow0 = (0.0070000000000000062 * double(fVslider0));
182 double fSlow1 = (0.0070000000000000062 * double(fVslider1));
183 double fSlow2 = (0.0070000000000000062 * double(fVslider2));
184 for (int i0 = 0; (i0 < ReCount); i0 = (i0 + 1)) {
185 fRec4[0] = (double(buf[i0]) - (fConst12 * ((fConst15 * fRec4[2]) + (0.000438032628543473 * fRec4[1]))));
186 fRec5[0] = (fSlow0 + (0.99299999999999999 * fRec5[1]));
187 double fTemp0 = ((fConst0 * (fConst22 + (fRec5[0] * (fConst23 + (fConst24 * fRec5[0]))))) + 0.000146000960455196);
188 fRec3[0] = ((fConst12 * ((fConst14 * fRec4[2]) + (fConst13 * fRec4[0]))) - (((fRec3[1] * ((fConst1 * ((fRec5[0] * ((2.2689303962825102e-09 * fRec5[0]) + -2.2462410923196899e-09)) + -2.5642240040785998e-10)) + 0.00029200192091039201)) + (fRec3[2] * ((fConst0 * (fConst17 + (fRec5[0] * (fConst19 + (fConst21 * fRec5[0]))))) + 0.000146000960455196))) / fTemp0));
189 fRec2[0] = ((0.31830988618379069 * std::atan((fConst0 * ((((fRec3[0] * (fConst26 + (fConst28 * fRec5[0]))) + (fConst0 * (fRec3[1] * ((0.0 - (4.5258677430700104e-12 * fRec5[0])) + -4.5258677430700099e-14)))) + (fRec3[2] * (fConst29 + (fConst30 * fRec5[0])))) / fTemp0)))) - (fConst8 * ((fConst31 * fRec2[1]) + (fConst32 * fRec2[2]))));
190 fRec1[0] = (double(symclip(double((fConst8 * (((fConst10 * fRec2[0]) + (fConst33 * fRec2[1])) + (fConst34 * fRec2[2])))))) - (fConst6 * ((fConst36 * fRec1[1]) + (fConst37 * fRec1[2]))));
191 fRec6[0] = (fSlow1 + (0.99299999999999999 * fRec6[1]));
192 double fTemp1 = ((fConst39 * fRec6[0]) + 0.0040143591413848399);
193 fRec0[0] = ((fConst6 * (((fRec1[0] * (fConst38 + fTemp1)) + (fRec1[1] * ((fConst40 * fRec6[0]) + 0.0080287182827696903))) + (fRec1[2] * (fTemp1 - fConst38)))) - (fConst41 * ((fConst42 * fRec0[1]) + (fConst43 * fRec0[2]))));
194 fRec7[0] = (fSlow2 + (0.99299999999999999 * fRec7[1]));
195 double fTemp2 = (0.0 - (1.74325899023428e-09 * fRec7[0]));
196 buf[i0] = FAUSTFLOAT((fConst4 * (((fRec0[0] * fTemp2) + (3.4865179804685599e-09 * (fRec7[0] * fRec0[1]))) + (fRec0[2] * fTemp2))));
197 fRec4[2] = fRec4[1];
198 fRec4[1] = fRec4[0];
199 fRec5[1] = fRec5[0];
200 fRec3[2] = fRec3[1];
201 fRec3[1] = fRec3[0];
202 fRec2[2] = fRec2[1];
203 fRec2[1] = fRec2[0];
204 fRec1[2] = fRec1[1];
205 fRec1[1] = fRec1[0];
206 fRec6[1] = fRec6[0];
207 fRec0[2] = fRec0[1];
208 fRec0[1] = fRec0[0];
209 fRec7[1] = fRec7[0];
210 }
211 smp.down(buf, output0);
212 }
213
compute_static(int count,FAUSTFLOAT * input0,FAUSTFLOAT * output0,PluginDef * p)214 void __rt_func Dsp::compute_static(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0, PluginDef *p)
215 {
216 static_cast<Dsp*>(p)->compute(count, input0, output0);
217 }
218
register_par(const ParamReg & reg)219 int Dsp::register_par(const ParamReg& reg)
220 {
221 reg.registerFloatVar("bmp.Sustain",N_("Sustain"),"S","",&fVslider0, 0.5, 0.0, 1.0, 0.01, 0);
222 reg.registerFloatVar("bmp.Tone",N_("Tone"),"S","",&fVslider1, 0.5, 0.0, 1.0, 0.01, 0);
223 reg.registerFloatVar("bmp.Volume",N_("Volume"),"S","",&fVslider2, 0.5, 0.0, 1.0, 0.01, 0);
224 return 0;
225 }
226
register_params_static(const ParamReg & reg)227 int Dsp::register_params_static(const ParamReg& reg)
228 {
229 return static_cast<Dsp*>(reg.plugin)->register_par(reg);
230 }
231
232 const char *Dsp::glade_def = "\
233 <?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
234 <!-- Generated with glade 3.22.1 -->\n\
235 <interface>\n\
236 <requires lib=\"gtk+\" version=\"3.20\"/>\n\
237 <requires lib=\"gxwidgets\" version=\"0.0\"/>\n\
238 <object class=\"GtkWindow\" id=\"window1\">\n\
239 <property name=\"can_focus\">False</property>\n\
240 <child>\n\
241 <placeholder/>\n\
242 </child>\n\
243 <child>\n\
244 <object class=\"GtkBox\" id=\"vbox1\">\n\
245 <property name=\"visible\">True</property>\n\
246 <property name=\"can_focus\">False</property>\n\
247 <property name=\"orientation\">vertical</property>\n\
248 <child>\n\
249 <object class=\"GtkBox\" id=\"rackbox\">\n\
250 <property name=\"visible\">True</property>\n\
251 <property name=\"can_focus\">False</property>\n\
252 <property name=\"spacing\">4</property>\n\
253 <child>\n\
254 <object class=\"GtkBox\" id=\"hbox1\">\n\
255 <property name=\"visible\">True</property>\n\
256 <property name=\"can_focus\">False</property>\n\
257 <property name=\"spacing\">10</property>\n\
258 <child>\n\
259 <object class=\"GtkBox\" id=\"vbox2\">\n\
260 <property name=\"visible\">True</property>\n\
261 <property name=\"can_focus\">False</property>\n\
262 <property name=\"orientation\">vertical</property>\n\
263 <child>\n\
264 <object class=\"GtkLabel\" id=\"label1:rack_label\">\n\
265 <property name=\"visible\">True</property>\n\
266 <property name=\"can_focus\">False</property>\n\
267 <property name=\"label\" translatable=\"yes\">label</property>\n\
268 </object>\n\
269 <packing>\n\
270 <property name=\"expand\">False</property>\n\
271 <property name=\"fill\">False</property>\n\
272 <property name=\"position\">0</property>\n\
273 </packing>\n\
274 </child>\n\
275 <child>\n\
276 <object class=\"GxSmallKnobR\" id=\"gxbigknob1\">\n\
277 <property name=\"visible\">True</property>\n\
278 <property name=\"can_focus\">True</property>\n\
279 <property name=\"receives_default\">True</property>\n\
280 <property name=\"var_id\">bmp.Volume</property>\n\
281 <property name=\"label_ref\">label1:rack_label</property>\n\
282 </object>\n\
283 <packing>\n\
284 <property name=\"expand\">False</property>\n\
285 <property name=\"fill\">False</property>\n\
286 <property name=\"position\">1</property>\n\
287 </packing>\n\
288 </child>\n\
289 </object>\n\
290 <packing>\n\
291 <property name=\"expand\">False</property>\n\
292 <property name=\"fill\">False</property>\n\
293 <property name=\"position\">0</property>\n\
294 </packing>\n\
295 </child>\n\
296 <child>\n\
297 <object class=\"GtkBox\" id=\"vbox3\">\n\
298 <property name=\"visible\">True</property>\n\
299 <property name=\"can_focus\">False</property>\n\
300 <property name=\"orientation\">vertical</property>\n\
301 <child>\n\
302 <object class=\"GtkLabel\" id=\"label2:rack_label\">\n\
303 <property name=\"visible\">True</property>\n\
304 <property name=\"can_focus\">False</property>\n\
305 <property name=\"label\" translatable=\"yes\">label</property>\n\
306 </object>\n\
307 <packing>\n\
308 <property name=\"expand\">False</property>\n\
309 <property name=\"fill\">False</property>\n\
310 <property name=\"position\">0</property>\n\
311 </packing>\n\
312 </child>\n\
313 <child>\n\
314 <object class=\"GxMidKnob\" id=\"gxbigknob2\">\n\
315 <property name=\"visible\">True</property>\n\
316 <property name=\"can_focus\">True</property>\n\
317 <property name=\"receives_default\">True</property>\n\
318 <property name=\"var_id\">bmp.Tone</property>\n\
319 <property name=\"label_ref\">label2:rack_label</property>\n\
320 </object>\n\
321 <packing>\n\
322 <property name=\"expand\">False</property>\n\
323 <property name=\"fill\">False</property>\n\
324 <property name=\"position\">1</property>\n\
325 </packing>\n\
326 </child>\n\
327 </object>\n\
328 <packing>\n\
329 <property name=\"expand\">False</property>\n\
330 <property name=\"fill\">False</property>\n\
331 <property name=\"position\">1</property>\n\
332 </packing>\n\
333 </child>\n\
334 <child>\n\
335 <object class=\"GtkBox\" id=\"vbox4\">\n\
336 <property name=\"visible\">True</property>\n\
337 <property name=\"can_focus\">False</property>\n\
338 <property name=\"orientation\">vertical</property>\n\
339 <child>\n\
340 <object class=\"GtkLabel\" id=\"label3:rack_label\">\n\
341 <property name=\"visible\">True</property>\n\
342 <property name=\"can_focus\">False</property>\n\
343 <property name=\"label\" translatable=\"yes\">label</property>\n\
344 </object>\n\
345 <packing>\n\
346 <property name=\"expand\">False</property>\n\
347 <property name=\"fill\">False</property>\n\
348 <property name=\"position\">0</property>\n\
349 </packing>\n\
350 </child>\n\
351 <child>\n\
352 <object class=\"GxSmallKnobR\" id=\"gxbigknob3\">\n\
353 <property name=\"visible\">True</property>\n\
354 <property name=\"can_focus\">True</property>\n\
355 <property name=\"receives_default\">True</property>\n\
356 <property name=\"var_id\">bmp.Sustain</property>\n\
357 <property name=\"label_ref\">label3:rack_label</property>\n\
358 </object>\n\
359 <packing>\n\
360 <property name=\"expand\">False</property>\n\
361 <property name=\"fill\">False</property>\n\
362 <property name=\"position\">1</property>\n\
363 </packing>\n\
364 </child>\n\
365 </object>\n\
366 <packing>\n\
367 <property name=\"expand\">False</property>\n\
368 <property name=\"fill\">False</property>\n\
369 <property name=\"position\">2</property>\n\
370 </packing>\n\
371 </child>\n\
372 </object>\n\
373 <packing>\n\
374 <property name=\"expand\">True</property>\n\
375 <property name=\"fill\">False</property>\n\
376 <property name=\"pack_type\">end</property>\n\
377 <property name=\"position\">0</property>\n\
378 </packing>\n\
379 </child>\n\
380 </object>\n\
381 <packing>\n\
382 <property name=\"expand\">True</property>\n\
383 <property name=\"fill\">False</property>\n\
384 <property name=\"position\">0</property>\n\
385 </packing>\n\
386 </child>\n\
387 <child>\n\
388 <object class=\"GtkBox\" id=\"minibox\">\n\
389 <property name=\"visible\">True</property>\n\
390 <property name=\"can_focus\">False</property>\n\
391 <property name=\"spacing\">4</property>\n\
392 <child>\n\
393 <object class=\"GxHSlider\" id=\"gxhslider1\">\n\
394 <property name=\"visible\">True</property>\n\
395 <property name=\"can_focus\">True</property>\n\
396 <property name=\"receives_default\">True</property>\n\
397 <property name=\"round_digits\">0</property>\n\
398 <property name=\"var_id\">bmp.Sustain</property>\n\
399 <property name=\"show_value\">False</property>\n\
400 <property name=\"value_position\">right</property>\n\
401 <property name=\"value_xalign\">0.52000000000000002</property>\n\
402 <property name=\"label_ref\">label0:rack_label</property>\n\
403 </object>\n\
404 <packing>\n\
405 <property name=\"expand\">False</property>\n\
406 <property name=\"fill\">False</property>\n\
407 <property name=\"position\">0</property>\n\
408 </packing>\n\
409 </child>\n\
410 <child>\n\
411 <object class=\"GtkLabel\" id=\"label0:rack_label\">\n\
412 <property name=\"visible\">True</property>\n\
413 <property name=\"can_focus\">False</property>\n\
414 <property name=\"label\" translatable=\"yes\">Drive</property>\n\
415 <property name=\"xalign\">0</property>\n\
416 </object>\n\
417 <packing>\n\
418 <property name=\"expand\">False</property>\n\
419 <property name=\"fill\">False</property>\n\
420 <property name=\"position\">1</property>\n\
421 </packing>\n\
422 </child>\n\
423 </object>\n\
424 <packing>\n\
425 <property name=\"expand\">True</property>\n\
426 <property name=\"fill\">True</property>\n\
427 <property name=\"position\">1</property>\n\
428 </packing>\n\
429 </child>\n\
430 </object>\n\
431 </child>\n\
432 </object>\n\
433 </interface>\n\
434 ";
435
load_ui_f(const UiBuilder & b,int form)436 inline int Dsp::load_ui_f(const UiBuilder& b, int form)
437 {
438 if (form & UI_FORM_GLADE) {
439 b.load_glade(glade_def);
440 return 0;
441 }
442 if (form & UI_FORM_STACK) {
443 #define PARAM(p) ("bmp" "." p)
444
445 b.openHorizontalhideBox("");
446 b.create_master_slider(PARAM("Sustain"), "Sustain");
447 b.closeBox();
448 b.openHorizontalBox("");
449
450 b.create_small_rackknobr(PARAM("Sustain"), "Sustain");
451 b.create_small_rackknobr(PARAM("Tone"), "Tone");
452 b.create_small_rackknobr(PARAM("Volume"), "Volume");
453 b.closeBox();
454
455 #undef PARAM
456 return 0;
457 }
458 return -1;
459 }
460
load_ui_f_static(const UiBuilder & b,int form)461 int Dsp::load_ui_f_static(const UiBuilder& b, int form)
462 {
463 return static_cast<Dsp*>(b.plugin)->load_ui_f(b, form);
464 }
plugin()465 PluginDef *plugin() {
466 return new Dsp();
467 }
468
del_instance(PluginDef * p)469 void Dsp::del_instance(PluginDef *p)
470 {
471 delete static_cast<Dsp*>(p);
472 }
473
474 } // end namespace bmp
475 } // end namespace pluginlib
476