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