1 // generated from file '../src/faust/gx_distortion.dsp' by dsp2cc:
2 // Code generated with Faust (https://faust.grame.fr)
3 
4 
5 namespace gx_distortion {
6 
7 class Dsp: public PluginDef {
8 private:
9 	int fSampleRate;
10 	double fConst2;
11 	double fConst3;
12 	int iVec0[2];
13 	FAUSTFLOAT fVslider0;
14 	double fRec1[2];
15 	FAUSTFLOAT fVslider1;
16 	FAUSTFLOAT fVslider2;
17 	FAUSTFLOAT fVslider3;
18 	double fConst4;
19 	FAUSTFLOAT fEntry0;
20 	double fConst7;
21 	double fConst11;
22 	double fRec8[2];
23 	FAUSTFLOAT fCheckbox0;
24 	FAUSTFLOAT fVslider4;
25 	FAUSTFLOAT fVslider5;
26 	double fVec1[2];
27 	FAUSTFLOAT fVslider6;
28 	double fRec9[2];
29 	double fConst12;
30 	double fConst13;
31 	double fRec7[3];
32 	double fVec2[2];
33 	double fConst14;
34 	double fConst15;
35 	double fRec6[2];
36 	double fRec5[2];
37 	double fRec4[3];
38 	FAUSTFLOAT fEntry1;
39 	double fRec3[3];
40 	FAUSTFLOAT fEntry2;
41 	double fRec2[3];
42 	FAUSTFLOAT fVslider7;
43 	double fRec10[2];
44 	FAUSTFLOAT fVslider8;
45 	double fRec15[2];
46 	double fRec14[3];
47 	double fVec3[2];
48 	double fRec13[2];
49 	double fRec12[3];
50 	double fRec11[3];
51 	FAUSTFLOAT fVslider9;
52 	double fRec16[2];
53 	FAUSTFLOAT fVslider10;
54 	double fRec20[2];
55 	double fRec19[3];
56 	double fVec4[2];
57 	double fRec18[2];
58 	double fRec17[3];
59 	FAUSTFLOAT fVslider11;
60 	double fRec21[2];
61 	FAUSTFLOAT fVslider12;
62 	double fRec23[2];
63 	double fRec22[3];
64 	double fVec5[2];
65 	double fRec0[2];
66 	FAUSTFLOAT fVslider13;
67 	double fRec24[2];
68 
69 	void clear_state_f();
70 	int load_ui_f(const UiBuilder& b, int form);
71 	void init(unsigned int sample_rate);
72 	void compute(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0);
73 	int register_par(const ParamReg& reg);
74 
75 	static void clear_state_f_static(PluginDef*);
76 	static int load_ui_f_static(const UiBuilder& b, int form);
77 	static void init_static(unsigned int sample_rate, PluginDef*);
78 	static void compute_static(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0, PluginDef*);
79 	static int register_params_static(const ParamReg& reg);
80 	static void del_instance(PluginDef *p);
81 public:
82 	Dsp();
83 	~Dsp();
84 };
85 
86 
87 
88 static const char* parm_groups[] = {
89 	"resonator", N_("Distortion resonator"),
90 	0
91 	};
92 
Dsp()93 Dsp::Dsp()
94 	: PluginDef() {
95 	version = PLUGINDEF_VERSION;
96 	flags = 0;
97 	id = "gx_distortion";
98 	name = N_("Multi Band Distortion");
99 	groups = parm_groups;
100 	description = ""; // description (tooltip)
101 	category = N_("Distortion");       // category
102 	shortname = N_("Distortion");     // shortname
103 	mono_audio = compute_static;
104 	stereo_audio = 0;
105 	set_samplerate = init_static;
106 	activate_plugin = 0;
107 	register_params = register_params_static;
108 	load_ui = load_ui_f_static;
109 	clear_state = clear_state_f_static;
110 	delete_instance = del_instance;
111 }
112 
~Dsp()113 Dsp::~Dsp() {
114 }
115 
clear_state_f()116 inline void Dsp::clear_state_f()
117 {
118 	for (int l0 = 0; (l0 < 2); l0 = (l0 + 1)) iVec0[l0] = 0;
119 	for (int l1 = 0; (l1 < 2); l1 = (l1 + 1)) fRec1[l1] = 0.0;
120 	for (int l2 = 0; (l2 < 2); l2 = (l2 + 1)) fRec8[l2] = 0.0;
121 	for (int l3 = 0; (l3 < 2); l3 = (l3 + 1)) fVec1[l3] = 0.0;
122 	for (int l4 = 0; (l4 < 2); l4 = (l4 + 1)) fRec9[l4] = 0.0;
123 	for (int l5 = 0; (l5 < 3); l5 = (l5 + 1)) fRec7[l5] = 0.0;
124 	for (int l6 = 0; (l6 < 2); l6 = (l6 + 1)) fVec2[l6] = 0.0;
125 	for (int l7 = 0; (l7 < 2); l7 = (l7 + 1)) fRec6[l7] = 0.0;
126 	for (int l8 = 0; (l8 < 2); l8 = (l8 + 1)) fRec5[l8] = 0.0;
127 	for (int l9 = 0; (l9 < 3); l9 = (l9 + 1)) fRec4[l9] = 0.0;
128 	for (int l10 = 0; (l10 < 3); l10 = (l10 + 1)) fRec3[l10] = 0.0;
129 	for (int l11 = 0; (l11 < 3); l11 = (l11 + 1)) fRec2[l11] = 0.0;
130 	for (int l12 = 0; (l12 < 2); l12 = (l12 + 1)) fRec10[l12] = 0.0;
131 	for (int l13 = 0; (l13 < 2); l13 = (l13 + 1)) fRec15[l13] = 0.0;
132 	for (int l14 = 0; (l14 < 3); l14 = (l14 + 1)) fRec14[l14] = 0.0;
133 	for (int l15 = 0; (l15 < 2); l15 = (l15 + 1)) fVec3[l15] = 0.0;
134 	for (int l16 = 0; (l16 < 2); l16 = (l16 + 1)) fRec13[l16] = 0.0;
135 	for (int l17 = 0; (l17 < 3); l17 = (l17 + 1)) fRec12[l17] = 0.0;
136 	for (int l18 = 0; (l18 < 3); l18 = (l18 + 1)) fRec11[l18] = 0.0;
137 	for (int l19 = 0; (l19 < 2); l19 = (l19 + 1)) fRec16[l19] = 0.0;
138 	for (int l20 = 0; (l20 < 2); l20 = (l20 + 1)) fRec20[l20] = 0.0;
139 	for (int l21 = 0; (l21 < 3); l21 = (l21 + 1)) fRec19[l21] = 0.0;
140 	for (int l22 = 0; (l22 < 2); l22 = (l22 + 1)) fVec4[l22] = 0.0;
141 	for (int l23 = 0; (l23 < 2); l23 = (l23 + 1)) fRec18[l23] = 0.0;
142 	for (int l24 = 0; (l24 < 3); l24 = (l24 + 1)) fRec17[l24] = 0.0;
143 	for (int l25 = 0; (l25 < 2); l25 = (l25 + 1)) fRec21[l25] = 0.0;
144 	for (int l26 = 0; (l26 < 2); l26 = (l26 + 1)) fRec23[l26] = 0.0;
145 	for (int l27 = 0; (l27 < 3); l27 = (l27 + 1)) fRec22[l27] = 0.0;
146 	for (int l28 = 0; (l28 < 2); l28 = (l28 + 1)) fVec5[l28] = 0.0;
147 	for (int l29 = 0; (l29 < 2); l29 = (l29 + 1)) fRec0[l29] = 0.0;
148 	for (int l30 = 0; (l30 < 2); l30 = (l30 + 1)) fRec24[l30] = 0.0;
149 }
150 
clear_state_f_static(PluginDef * p)151 void Dsp::clear_state_f_static(PluginDef *p)
152 {
153 	static_cast<Dsp*>(p)->clear_state_f();
154 }
155 
init(unsigned int sample_rate)156 inline void Dsp::init(unsigned int sample_rate)
157 {
158 	fSampleRate = sample_rate;
159 	double fConst0 = std::min<double>(192000.0, std::max<double>(1.0, double(fSampleRate)));
160 	double fConst1 = (1.0 / std::tan((20517.741620594938 / fConst0)));
161 	fConst2 = (1.0 / (fConst1 + 1.0));
162 	fConst3 = (1.0 - fConst1);
163 	fConst4 = (3.1415926535897931 / fConst0);
164 	double fConst5 = std::tan((47123.889803846898 / fConst0));
165 	double fConst6 = (1.0 / fConst5);
166 	fConst7 = (1.0 / (((fConst6 + 1.4142135623730949) / fConst5) + 1.0));
167 	double fConst8 = std::tan((97.389372261283583 / fConst0));
168 	double fConst9 = (1.0 / fConst8);
169 	double fConst10 = (fConst9 + 1.0);
170 	fConst11 = (1.0 / (fConst8 * fConst10));
171 	fConst12 = (((fConst6 + -1.4142135623730949) / fConst5) + 1.0);
172 	fConst13 = (2.0 * (1.0 - (1.0 / mydsp_faustpower2_f(fConst5))));
173 	fConst14 = (0.0 - fConst11);
174 	fConst15 = ((1.0 - fConst9) / fConst10);
175 	clear_state_f();
176 }
177 
init_static(unsigned int sample_rate,PluginDef * p)178 void Dsp::init_static(unsigned int sample_rate, PluginDef *p)
179 {
180 	static_cast<Dsp*>(p)->init(sample_rate);
181 }
182 
compute(int count,FAUSTFLOAT * input0,FAUSTFLOAT * output0)183 void always_inline Dsp::compute(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0)
184 {
185 	double fSlow0 = (0.0010000000000000009 * std::pow(10.0, (0.050000000000000003 * (double(fVslider0) + -10.0))));
186 	double fSlow1 = double(fVslider1);
187 	double fSlow2 = double(fVslider2);
188 	double fSlow3 = std::pow(10.0, (2.0 * (fSlow2 * double(fVslider3))));
189 	double fSlow4 = std::tan((fConst4 * double(fEntry0)));
190 	double fSlow5 = (1.0 / fSlow4);
191 	double fSlow6 = (((fSlow5 + 1.0000000000000004) / fSlow4) + 1.0);
192 	double fSlow7 = (1.0 / fSlow6);
193 	double fSlow8 = mydsp_faustpower2_f(fSlow4);
194 	double fSlow9 = (1.0 / fSlow8);
195 	double fSlow10 = (fSlow5 + 1.0);
196 	double fSlow11 = (0.0 - (1.0 / (fSlow4 * fSlow10)));
197 	int iSlow12 = int(double(fCheckbox0));
198 	double fSlow13 = (0.01 * double(fVslider4));
199 	double fSlow14 = (1.0 - double(fVslider5));
200 	double fSlow15 = double(fVslider6);
201 	int iSlow16 = int(std::min<double>(4096.0, std::max<double>(0.0, (fSlow15 + -1.0))));
202 	int iSlow17 = int(std::min<double>(4096.0, std::max<double>(0.0, fSlow15)));
203 	double fSlow18 = (1.0 / fSlow10);
204 	double fSlow19 = (1.0 - fSlow5);
205 	double fSlow20 = (((fSlow5 + -1.0000000000000004) / fSlow4) + 1.0);
206 	double fSlow21 = (2.0 * (1.0 - fSlow9));
207 	double fSlow22 = (0.0 - (2.0 / fSlow8));
208 	double fSlow23 = std::tan((fConst4 * double(fEntry1)));
209 	double fSlow24 = (1.0 / fSlow23);
210 	double fSlow25 = (fSlow24 + 1.0);
211 	double fSlow26 = (1.0 / ((fSlow25 / fSlow23) + 1.0));
212 	double fSlow27 = (1.0 - fSlow24);
213 	double fSlow28 = (1.0 - (fSlow27 / fSlow23));
214 	double fSlow29 = mydsp_faustpower2_f(fSlow23);
215 	double fSlow30 = (1.0 / fSlow29);
216 	double fSlow31 = (2.0 * (1.0 - fSlow30));
217 	double fSlow32 = std::tan((fConst4 * double(fEntry2)));
218 	double fSlow33 = (1.0 / fSlow32);
219 	double fSlow34 = (fSlow33 + 1.0);
220 	double fSlow35 = (1.0 / ((fSlow34 / fSlow32) + 1.0));
221 	double fSlow36 = (1.0 - fSlow33);
222 	double fSlow37 = (1.0 - (fSlow36 / fSlow32));
223 	double fSlow38 = mydsp_faustpower2_f(fSlow32);
224 	double fSlow39 = (1.0 / fSlow38);
225 	double fSlow40 = (2.0 * (1.0 - fSlow39));
226 	double fSlow41 = (0.0010000000000000009 * std::pow(10.0, (0.050000000000000003 * (double(fVslider7) + -10.0))));
227 	double fSlow42 = std::pow(10.0, (2.0 * (fSlow2 * double(fVslider8))));
228 	double fSlow43 = (((fSlow24 + 1.0000000000000004) / fSlow23) + 1.0);
229 	double fSlow44 = (1.0 / fSlow43);
230 	double fSlow45 = (0.0 - (1.0 / (fSlow23 * fSlow25)));
231 	double fSlow46 = (1.0 / fSlow25);
232 	double fSlow47 = (1.0 / (fSlow23 * fSlow6));
233 	double fSlow48 = (((fSlow24 + -1.0000000000000004) / fSlow23) + 1.0);
234 	double fSlow49 = (0.0 - (2.0 / fSlow29));
235 	double fSlow50 = (0.0010000000000000009 * std::pow(10.0, (0.050000000000000003 * (double(fVslider9) + -10.0))));
236 	double fSlow51 = (((fSlow33 + 1.0000000000000004) / fSlow32) + 1.0);
237 	double fSlow52 = (std::pow(10.0, (2.0 * (fSlow2 * double(fVslider10)))) / fSlow51);
238 	double fSlow53 = (0.0 - (1.0 / (fSlow32 * fSlow34)));
239 	double fSlow54 = (1.0 / fSlow34);
240 	double fSlow55 = (1.0 / (fSlow32 * fSlow43));
241 	double fSlow56 = (1.0 / fSlow51);
242 	double fSlow57 = (((fSlow33 + -1.0000000000000004) / fSlow32) + 1.0);
243 	double fSlow58 = (0.0 - (2.0 / fSlow38));
244 	double fSlow59 = (0.0010000000000000009 * std::pow(10.0, (0.050000000000000003 * (double(fVslider11) + -10.0))));
245 	double fSlow60 = (std::pow(10.0, (2.0 * (fSlow2 * double(fVslider12)))) / fSlow51);
246 	double fSlow61 = (0.0010000000000000009 * std::pow(10.0, (0.050000000000000003 * (double(fVslider13) + -10.0))));
247 	double fSlow62 = (1.0 - fSlow13);
248 	for (int i0 = 0; (i0 < count); i0 = (i0 + 1)) {
249 		iVec0[0] = 1;
250 		fRec1[0] = (fSlow0 + (0.999 * fRec1[1]));
251 		fRec8[0] = ((9.9999999999999995e-21 * double((1 - iVec0[1]))) - fRec8[1]);
252 		double fTemp0 = double(input0[i0]);
253 		double fTemp1 = (fSlow13 * fTemp0);
254 		double fTemp2 = (fTemp1 + (fSlow14 * fRec9[1]));
255 		fVec1[0] = fTemp2;
256 		fRec9[0] = (0.5 * (fVec1[iSlow16] + fVec1[iSlow17]));
257 		fRec7[0] = ((fRec8[0] + (iSlow12 ? fRec9[0] : fTemp1)) - (fConst7 * ((fConst12 * fRec7[2]) + (fConst13 * fRec7[1]))));
258 		double fTemp3 = (fRec7[2] + (fRec7[0] + (2.0 * fRec7[1])));
259 		fVec2[0] = fTemp3;
260 		fRec6[0] = ((fConst7 * ((fConst11 * fTemp3) + (fConst14 * fVec2[1]))) - (fConst15 * fRec6[1]));
261 		fRec5[0] = ((fSlow11 * fRec6[1]) - (fSlow18 * ((fSlow19 * fRec5[1]) - (fSlow5 * fRec6[0]))));
262 		fRec4[0] = (fRec5[0] - (fSlow7 * ((fSlow20 * fRec4[2]) + (fSlow21 * fRec4[1]))));
263 		double fTemp4 = (fSlow31 * fRec3[1]);
264 		fRec3[0] = ((fSlow7 * (((fSlow9 * fRec4[0]) + (fSlow22 * fRec4[1])) + (fSlow9 * fRec4[2]))) - (fSlow26 * ((fSlow28 * fRec3[2]) + fTemp4)));
265 		double fTemp5 = (fSlow40 * fRec2[1]);
266 		fRec2[0] = ((fRec3[2] + (fSlow26 * (fTemp4 + (fSlow28 * fRec3[0])))) - (fSlow35 * ((fSlow37 * fRec2[2]) + fTemp5)));
267 		double fTemp6 = std::max<double>(-1.0, std::min<double>(1.0, (fSlow1 + (fSlow3 * (fRec2[2] + (fSlow35 * (fTemp5 + (fSlow37 * fRec2[0]))))))));
268 		fRec10[0] = (fSlow41 + (0.999 * fRec10[1]));
269 		fRec15[0] = (0.0 - (fSlow18 * ((fSlow19 * fRec15[1]) - (fRec6[0] + fRec6[1]))));
270 		fRec14[0] = (fRec15[0] - (fSlow7 * ((fSlow20 * fRec14[2]) + (fSlow21 * fRec14[1]))));
271 		double fTemp7 = (fRec14[2] + (fRec14[0] + (2.0 * fRec14[1])));
272 		double fTemp8 = (fSlow7 * fTemp7);
273 		fVec3[0] = fTemp8;
274 		fRec13[0] = ((fSlow45 * fVec3[1]) - (fSlow46 * ((fSlow27 * fRec13[1]) - (fSlow47 * fTemp7))));
275 		fRec12[0] = (fRec13[0] - (fSlow44 * ((fSlow48 * fRec12[2]) + (fSlow31 * fRec12[1]))));
276 		double fTemp9 = (fSlow40 * fRec11[1]);
277 		fRec11[0] = ((fSlow44 * (((fSlow30 * fRec12[0]) + (fSlow49 * fRec12[1])) + (fSlow30 * fRec12[2]))) - (fSlow35 * ((fSlow37 * fRec11[2]) + fTemp9)));
278 		double fTemp10 = std::max<double>(-1.0, std::min<double>(1.0, (fSlow1 + (fSlow42 * (fRec11[2] + (fSlow35 * (fTemp9 + (fSlow37 * fRec11[0]))))))));
279 		fRec16[0] = (fSlow50 + (0.999 * fRec16[1]));
280 		fRec20[0] = (0.0 - (fSlow46 * ((fSlow27 * fRec20[1]) - (fTemp8 + fVec3[1]))));
281 		fRec19[0] = (fRec20[0] - (fSlow44 * ((fSlow48 * fRec19[2]) + (fSlow31 * fRec19[1]))));
282 		double fTemp11 = (fRec19[2] + (fRec19[0] + (2.0 * fRec19[1])));
283 		double fTemp12 = (fSlow44 * fTemp11);
284 		fVec4[0] = fTemp12;
285 		fRec18[0] = ((fSlow53 * fVec4[1]) - (fSlow54 * ((fSlow36 * fRec18[1]) - (fSlow55 * fTemp11))));
286 		fRec17[0] = (fRec18[0] - (fSlow56 * ((fSlow57 * fRec17[2]) + (fSlow40 * fRec17[1]))));
287 		double fTemp13 = std::max<double>(-1.0, std::min<double>(1.0, (fSlow1 + (fSlow52 * (((fSlow39 * fRec17[0]) + (fSlow58 * fRec17[1])) + (fSlow39 * fRec17[2]))))));
288 		fRec21[0] = (fSlow59 + (0.999 * fRec21[1]));
289 		fRec23[0] = (0.0 - (fSlow54 * ((fSlow36 * fRec23[1]) - (fTemp12 + fVec4[1]))));
290 		fRec22[0] = (fRec23[0] - (fSlow56 * ((fSlow57 * fRec22[2]) + (fSlow40 * fRec22[1]))));
291 		double fTemp14 = std::max<double>(-1.0, std::min<double>(1.0, (fSlow1 + (fSlow60 * (fRec22[2] + (fRec22[0] + (2.0 * fRec22[1])))))));
292 		double fTemp15 = (((((fRec1[0] * fTemp6) * (1.0 - (0.33333333333333331 * mydsp_faustpower2_f(fTemp6)))) + ((fRec10[0] * fTemp10) * (1.0 - (0.33333333333333331 * mydsp_faustpower2_f(fTemp10))))) + ((fRec16[0] * fTemp13) * (1.0 - (0.33333333333333331 * mydsp_faustpower2_f(fTemp13))))) + ((fRec21[0] * fTemp14) * (1.0 - (0.33333333333333331 * mydsp_faustpower2_f(fTemp14)))));
293 		fVec5[0] = fTemp15;
294 		fRec0[0] = (0.0 - (fConst2 * ((fConst3 * fRec0[1]) - (fTemp15 + fVec5[1]))));
295 		fRec24[0] = (fSlow61 + (0.999 * fRec24[1]));
296 		output0[i0] = FAUSTFLOAT(((fRec0[0] * fRec24[0]) + (fSlow62 * fTemp0)));
297 		iVec0[1] = iVec0[0];
298 		fRec1[1] = fRec1[0];
299 		fRec8[1] = fRec8[0];
300 		fVec1[1] = fVec1[0];
301 		fRec9[1] = fRec9[0];
302 		fRec7[2] = fRec7[1];
303 		fRec7[1] = fRec7[0];
304 		fVec2[1] = fVec2[0];
305 		fRec6[1] = fRec6[0];
306 		fRec5[1] = fRec5[0];
307 		fRec4[2] = fRec4[1];
308 		fRec4[1] = fRec4[0];
309 		fRec3[2] = fRec3[1];
310 		fRec3[1] = fRec3[0];
311 		fRec2[2] = fRec2[1];
312 		fRec2[1] = fRec2[0];
313 		fRec10[1] = fRec10[0];
314 		fRec15[1] = fRec15[0];
315 		fRec14[2] = fRec14[1];
316 		fRec14[1] = fRec14[0];
317 		fVec3[1] = fVec3[0];
318 		fRec13[1] = fRec13[0];
319 		fRec12[2] = fRec12[1];
320 		fRec12[1] = fRec12[0];
321 		fRec11[2] = fRec11[1];
322 		fRec11[1] = fRec11[0];
323 		fRec16[1] = fRec16[0];
324 		fRec20[1] = fRec20[0];
325 		fRec19[2] = fRec19[1];
326 		fRec19[1] = fRec19[0];
327 		fVec4[1] = fVec4[0];
328 		fRec18[1] = fRec18[0];
329 		fRec17[2] = fRec17[1];
330 		fRec17[1] = fRec17[0];
331 		fRec21[1] = fRec21[0];
332 		fRec23[1] = fRec23[0];
333 		fRec22[2] = fRec22[1];
334 		fRec22[1] = fRec22[0];
335 		fVec5[1] = fVec5[0];
336 		fRec0[1] = fRec0[0];
337 		fRec24[1] = fRec24[0];
338 	}
339 }
340 
compute_static(int count,FAUSTFLOAT * input0,FAUSTFLOAT * output0,PluginDef * p)341 void __rt_func Dsp::compute_static(int count, FAUSTFLOAT *input0, FAUSTFLOAT *output0, PluginDef *p)
342 {
343 	static_cast<Dsp*>(p)->compute(count, input0, output0);
344 }
345 
register_par(const ParamReg & reg)346 int Dsp::register_par(const ParamReg& reg)
347 {
348 	reg.registerFloatVar("gx_distortion.drive",N_("Drive"),"S","",&fVslider2, 0.64000000000000001, 0.0, 1.0, 0.01, 0);
349 	reg.registerFloatVar("gx_distortion.gain",N_("Gain"),"S","",&fVslider13, 2.0, -10.0, 10.0, 0.10000000000000001, 0);
350 	reg.registerFloatVar("gx_distortion.high_drive",N_("Hi"),"S","",&fVslider3, 1.0, 0.0, 1.0, 0.01, 0);
351 	reg.registerFloatVar("gx_distortion.high_gain",N_("Hi"),"S","",&fVslider0, 10.0, -10.0, 20.0, 0.10000000000000001, 0);
352 	reg.registerFloatVar("gx_distortion.level",N_("Level"),"S","",&fVslider1, 0.0, 0.0, 0.5, 0.01, 0);
353 	reg.registerFloatVar("gx_distortion.low_drive",N_("Lo"),"S","",&fVslider12, 1.0, 0.0, 1.0, 0.01, 0);
354 	reg.registerFloatVar("gx_distortion.low_gain",N_("Lo"),"S","",&fVslider11, 10.0, -10.0, 20.0, 0.10000000000000001, 0);
355 	reg.registerFloatVar("gx_distortion.middle_h_drive",N_("HiMid"),"S","",&fVslider8, 1.0, 0.0, 1.0, 0.01, 0);
356 	reg.registerFloatVar("gx_distortion.middle_h_gain",N_("HiMid"),"S","",&fVslider7, 10.0, -10.0, 20.0, 0.10000000000000001, 0);
357 	reg.registerFloatVar("gx_distortion.middle_l_drive",N_("LoMid"),"S","",&fVslider10, 1.0, 0.0, 1.0, 0.01, 0);
358 	reg.registerFloatVar("gx_distortion.middle_l_gain",N_("LoMid"),"S","",&fVslider9, 10.0, -10.0, 20.0, 0.10000000000000001, 0);
359 	reg.registerFloatVar("gx_distortion.resonator.on_off",N_("resonat"),"B","",&fCheckbox0, 0.0, 0.0, 1.0, 1.0, 0);
360 	reg.registerFloatVar("gx_distortion.split_high_freq",N_("Split Hi"),"S","",&fEntry0, 1250.0, 1250.0, 12000.0, 10.0, 0);
361 	reg.registerFloatVar("gx_distortion.split_low_freq",N_("Split Lo"),"S","",&fEntry2, 250.0, 20.0, 600.0, 10.0, 0);
362 	reg.registerFloatVar("gx_distortion.split_middle_freq",N_("Split Mid"),"S","",&fEntry1, 650.0, 600.0, 1250.0, 10.0, 0);
363 	reg.registerFloatVar("gx_distortion.trigger",N_("Trigger"),"S","",&fVslider5, 0.12, 0.0, 1.0, 0.01, 0);
364 	reg.registerFloatVar("gx_distortion.vibrato",N_("Vibrato"),"S","",&fVslider6, 1.0, 0.0, 1.0, 0.01, 0);
365 	reg.registerFloatVar("gx_distortion.wet_dry",N_("Wet/Dry"),"S",N_("percentage of processed signal in output signal"),&fVslider4, 100.0, 0.0, 100.0, 1.0, 0);
366 	return 0;
367 }
368 
register_params_static(const ParamReg & reg)369 int Dsp::register_params_static(const ParamReg& reg)
370 {
371 	return static_cast<Dsp*>(reg.plugin)->register_par(reg);
372 }
373 
load_ui_f(const UiBuilder & b,int form)374 inline int Dsp::load_ui_f(const UiBuilder& b, int form)
375 {
376     if (form & UI_FORM_GLADE) {
377         b.load_glade_file("gx_distortion_ui.glade");
378         return 0;
379     }
380     if (form & UI_FORM_STACK) {
381 #define PARAM(p) ("gx_distortion" "." p)
382 // ----- distortion
383 b.openHorizontalhideBox("");
384 b.create_master_slider("gx_distortion.drive", _("drive"));
385 b.closeBox();
386 b.openHorizontalBox("");
387 {
388     b.openVerticalBox("");
389     {
390 	b.openVerticalBox("");
391 	{
392 	    b.openFlipLabelBox(_("  drive "));
393 	    {
394 		b.openHorizontalBox("");
395 		{
396 		    b.create_small_rackknobr("gx_distortion.drive", _("  drive "));
397 		    b.create_small_rackknobr("gx_distortion.low_drive", _(" low "));
398 		    b.create_small_rackknobr("gx_distortion.middle_l_drive", _(" middle l. "));
399 		    b.create_small_rackknobr("gx_distortion.middle_h_drive", _(" middle h. "));
400 		    b.create_small_rackknobr("gx_distortion.high_drive", _(" high "));
401 		}
402 		b.closeBox();
403 	    }
404 	    b.closeBox();
405 	    b.openFlipLabelBox(_("  gain  "));
406 	    {
407 		b.openHorizontalBox("");
408 		{
409 		    b.create_small_rackknob("gx_distortion.gain", _("  gain  "));
410 		    b.create_small_rackknob("gx_distortion.low_gain", _(" low "));
411 		    b.create_small_rackknob("gx_distortion.middle_l_gain", _(" middle l. "));
412 		    b.create_small_rackknob("gx_distortion.middle_h_gain", _(" middle h. "));
413 		    b.create_small_rackknob("gx_distortion.high_gain", _(" high "));
414 		}
415 		b.closeBox();
416 	    }
417 	    b.closeBox();
418 	}
419 	b.closeBox();
420 
421 	b.openHorizontalBox("");
422 	{
423 	    b.create_small_rackknob("gx_distortion.wet_dry", _("dry/wet"));
424 	    b.create_small_rackknob("gx_distortion.level", _("  level  "));
425 	    b.openVerticalBox(_("frequency split Hz"));
426 	    {
427 		b.openpaintampBox("");
428 		{
429 		    b.openHorizontalBox("");
430 		    {
431 			b.insertSpacer();
432 			b.create_wheel("gx_distortion.split_low_freq", _("split low freq"));
433 			b.insertSpacer();
434 			b.create_wheel("gx_distortion.split_middle_freq", _("split m. freq"));
435 			b.insertSpacer();
436 			b.create_wheel("gx_distortion.split_high_freq", _("split high freq"));
437 			b.insertSpacer();
438 		    }
439 		    b.closeBox();
440 		}
441 		b.closeBox();
442 	    }
443 	    b.closeBox();
444 	}
445 	b.closeBox();
446     }
447     b.closeBox();
448 
449     b.openVerticalBox(_("resonator"));
450     {
451 	b.create_small_rackknob("gx_distortion.trigger", _("trigger "));
452 	b.create_small_rackknob("gx_distortion.vibrato", _(" vibrato "));
453 	b.create_switch_no_caption(sw_switchit, "gx_distortion.resonator.on_off");
454     }
455     b.closeBox();
456 }
457 b.closeBox();
458 
459 #undef PARAM
460         return 0;
461     }
462 	return -1;
463 }
464 
load_ui_f_static(const UiBuilder & b,int form)465 int Dsp::load_ui_f_static(const UiBuilder& b, int form)
466 {
467 	return static_cast<Dsp*>(b.plugin)->load_ui_f(b, form);
468 }
plugin()469 PluginDef *plugin() {
470 	return new Dsp();
471 }
472 
del_instance(PluginDef * p)473 void Dsp::del_instance(PluginDef *p)
474 {
475 	delete static_cast<Dsp*>(p);
476 }
477 
478 } // end namespace gx_distortion
479