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