1 // generated from file '../src/faust/panoram_enhancer.dsp' by dsp2cc:
2 // Code generated with Faust (https://faust.grame.fr)
3
4
5 namespace panoram_enhancer {
6
7 class Dsp: public PluginDef {
8 private:
9 int fSampleRate;
10 double fConst3;
11 FAUSTFLOAT fHslider0;
12 double fConst4;
13 double fConst5;
14 double fConst8;
15 double fConst10;
16 double fConst11;
17 double fConst12;
18 int IOTA;
19 double fVec0[131072];
20 double fConst13;
21 FAUSTFLOAT fHslider1;
22 double fRec6[2];
23 double fConst14;
24 double fConst15;
25 double fRec5[3];
26 double fConst16;
27 double fConst17;
28 double fRec4[3];
29 double fConst18;
30 double fRec3[3];
31 double fConst19;
32 double fConst21;
33 double fConst22;
34 double fRec2[3];
35 double fConst23;
36 double fRec1[3];
37 double fConst24;
38 double fRec0[3];
39 double fConst27;
40 double fConst28;
41 double fConst29;
42 double fConst30;
43 double fRec12[3];
44 double fConst31;
45 double fRec11[3];
46 double fRec10[3];
47 double fConst32;
48 double fConst34;
49 double fConst35;
50 double fRec9[3];
51 double fConst36;
52 double fRec8[3];
53 double fConst37;
54 double fRec7[3];
55 double fConst40;
56 double fConst41;
57 double fConst42;
58 double fConst43;
59 double fRec18[3];
60 double fConst44;
61 double fRec17[3];
62 double fRec16[3];
63 double fConst45;
64 double fConst46;
65 double fRec15[3];
66 double fConst47;
67 double fRec14[3];
68 double fConst48;
69 double fRec13[3];
70 double fConst49;
71 double fConst50;
72 double fVec1[131072];
73 double fConst51;
74 double fRec20[3];
75 double fConst52;
76 double fRec19[3];
77 double fConst53;
78 double fConst54;
79 double fRec26[3];
80 double fRec25[3];
81 double fRec24[3];
82 double fRec23[3];
83 double fRec22[3];
84 double fRec21[3];
85 double fRec32[3];
86 double fRec31[3];
87 double fRec30[3];
88 double fRec29[3];
89 double fRec28[3];
90 double fRec27[3];
91 double fConst55;
92 double fRec38[3];
93 double fRec37[3];
94 double fRec36[3];
95 double fRec35[3];
96 double fRec34[3];
97 double fRec33[3];
98
99 void clear_state_f();
100 int load_ui_f(const UiBuilder& b, int form);
101 static const char *glade_def;
102 void init(unsigned int sample_rate);
103 void compute(int count, FAUSTFLOAT *input0, FAUSTFLOAT *input1, FAUSTFLOAT *output0, FAUSTFLOAT *output1);
104 int register_par(const ParamReg& reg);
105
106 static void clear_state_f_static(PluginDef*);
107 static int load_ui_f_static(const UiBuilder& b, int form);
108 static void init_static(unsigned int sample_rate, PluginDef*);
109 static void compute_static(int count, FAUSTFLOAT *input0, FAUSTFLOAT *input1, FAUSTFLOAT *output0, FAUSTFLOAT *output1, PluginDef*);
110 static int register_params_static(const ParamReg& reg);
111 static void del_instance(PluginDef *p);
112 public:
113 Dsp();
114 ~Dsp();
115 };
116
117
118
Dsp()119 Dsp::Dsp()
120 : PluginDef() {
121 version = PLUGINDEF_VERSION;
122 flags = 0;
123 id = "panoram_enhancer";
124 name = N_("Panoram Enhancer");
125 groups = 0;
126 description = ""; // description (tooltip)
127 category = N_("Misc"); // category
128 shortname = N_("Panoram"); // shortname
129 mono_audio = 0;
130 stereo_audio = compute_static;
131 set_samplerate = init_static;
132 activate_plugin = 0;
133 register_params = register_params_static;
134 load_ui = load_ui_f_static;
135 clear_state = clear_state_f_static;
136 delete_instance = del_instance;
137 }
138
~Dsp()139 Dsp::~Dsp() {
140 }
141
clear_state_f()142 inline void Dsp::clear_state_f()
143 {
144 for (int l0 = 0; (l0 < 131072); l0 = (l0 + 1)) fVec0[l0] = 0.0;
145 for (int l1 = 0; (l1 < 2); l1 = (l1 + 1)) fRec6[l1] = 0.0;
146 for (int l2 = 0; (l2 < 3); l2 = (l2 + 1)) fRec5[l2] = 0.0;
147 for (int l3 = 0; (l3 < 3); l3 = (l3 + 1)) fRec4[l3] = 0.0;
148 for (int l4 = 0; (l4 < 3); l4 = (l4 + 1)) fRec3[l4] = 0.0;
149 for (int l5 = 0; (l5 < 3); l5 = (l5 + 1)) fRec2[l5] = 0.0;
150 for (int l6 = 0; (l6 < 3); l6 = (l6 + 1)) fRec1[l6] = 0.0;
151 for (int l7 = 0; (l7 < 3); l7 = (l7 + 1)) fRec0[l7] = 0.0;
152 for (int l8 = 0; (l8 < 3); l8 = (l8 + 1)) fRec12[l8] = 0.0;
153 for (int l9 = 0; (l9 < 3); l9 = (l9 + 1)) fRec11[l9] = 0.0;
154 for (int l10 = 0; (l10 < 3); l10 = (l10 + 1)) fRec10[l10] = 0.0;
155 for (int l11 = 0; (l11 < 3); l11 = (l11 + 1)) fRec9[l11] = 0.0;
156 for (int l12 = 0; (l12 < 3); l12 = (l12 + 1)) fRec8[l12] = 0.0;
157 for (int l13 = 0; (l13 < 3); l13 = (l13 + 1)) fRec7[l13] = 0.0;
158 for (int l14 = 0; (l14 < 3); l14 = (l14 + 1)) fRec18[l14] = 0.0;
159 for (int l15 = 0; (l15 < 3); l15 = (l15 + 1)) fRec17[l15] = 0.0;
160 for (int l16 = 0; (l16 < 3); l16 = (l16 + 1)) fRec16[l16] = 0.0;
161 for (int l17 = 0; (l17 < 3); l17 = (l17 + 1)) fRec15[l17] = 0.0;
162 for (int l18 = 0; (l18 < 3); l18 = (l18 + 1)) fRec14[l18] = 0.0;
163 for (int l19 = 0; (l19 < 3); l19 = (l19 + 1)) fRec13[l19] = 0.0;
164 for (int l20 = 0; (l20 < 131072); l20 = (l20 + 1)) fVec1[l20] = 0.0;
165 for (int l21 = 0; (l21 < 3); l21 = (l21 + 1)) fRec20[l21] = 0.0;
166 for (int l22 = 0; (l22 < 3); l22 = (l22 + 1)) fRec19[l22] = 0.0;
167 for (int l23 = 0; (l23 < 3); l23 = (l23 + 1)) fRec26[l23] = 0.0;
168 for (int l24 = 0; (l24 < 3); l24 = (l24 + 1)) fRec25[l24] = 0.0;
169 for (int l25 = 0; (l25 < 3); l25 = (l25 + 1)) fRec24[l25] = 0.0;
170 for (int l26 = 0; (l26 < 3); l26 = (l26 + 1)) fRec23[l26] = 0.0;
171 for (int l27 = 0; (l27 < 3); l27 = (l27 + 1)) fRec22[l27] = 0.0;
172 for (int l28 = 0; (l28 < 3); l28 = (l28 + 1)) fRec21[l28] = 0.0;
173 for (int l29 = 0; (l29 < 3); l29 = (l29 + 1)) fRec32[l29] = 0.0;
174 for (int l30 = 0; (l30 < 3); l30 = (l30 + 1)) fRec31[l30] = 0.0;
175 for (int l31 = 0; (l31 < 3); l31 = (l31 + 1)) fRec30[l31] = 0.0;
176 for (int l32 = 0; (l32 < 3); l32 = (l32 + 1)) fRec29[l32] = 0.0;
177 for (int l33 = 0; (l33 < 3); l33 = (l33 + 1)) fRec28[l33] = 0.0;
178 for (int l34 = 0; (l34 < 3); l34 = (l34 + 1)) fRec27[l34] = 0.0;
179 for (int l35 = 0; (l35 < 3); l35 = (l35 + 1)) fRec38[l35] = 0.0;
180 for (int l36 = 0; (l36 < 3); l36 = (l36 + 1)) fRec37[l36] = 0.0;
181 for (int l37 = 0; (l37 < 3); l37 = (l37 + 1)) fRec36[l37] = 0.0;
182 for (int l38 = 0; (l38 < 3); l38 = (l38 + 1)) fRec35[l38] = 0.0;
183 for (int l39 = 0; (l39 < 3); l39 = (l39 + 1)) fRec34[l39] = 0.0;
184 for (int l40 = 0; (l40 < 3); l40 = (l40 + 1)) fRec33[l40] = 0.0;
185 }
186
clear_state_f_static(PluginDef * p)187 void Dsp::clear_state_f_static(PluginDef *p)
188 {
189 static_cast<Dsp*>(p)->clear_state_f();
190 }
191
init(unsigned int sample_rate)192 inline void Dsp::init(unsigned int sample_rate)
193 {
194 fSampleRate = sample_rate;
195 double fConst0 = std::min<double>(192000.0, std::max<double>(1.0, double(fSampleRate)));
196 double fConst1 = std::tan((11309.733552923255 / fConst0));
197 double fConst2 = (1.0 / fConst1);
198 fConst3 = (1.0 / (((fConst2 + 0.51763809020504126) / fConst1) + 1.0));
199 fConst4 = (1.0 / (((fConst2 + 1.4142135623730949) / fConst1) + 1.0));
200 fConst5 = (1.0 / (((fConst2 + 1.9318516525781364) / fConst1) + 1.0));
201 double fConst6 = std::tan((5654.8667764616275 / fConst0));
202 double fConst7 = (1.0 / fConst6);
203 fConst8 = (1.0 / (((fConst7 + 0.51763809020504126) / fConst6) + 1.0));
204 double fConst9 = mydsp_faustpower2_f(fConst6);
205 fConst10 = (1.0 / fConst9);
206 fConst11 = (1.0 / (((fConst7 + 1.4142135623730949) / fConst6) + 1.0));
207 fConst12 = (1.0 / (((fConst7 + 1.9318516525781364) / fConst6) + 1.0));
208 fConst13 = (0.20000000000000001 * fConst0);
209 fConst14 = (((fConst7 + -1.9318516525781364) / fConst6) + 1.0);
210 fConst15 = (2.0 * (1.0 - fConst10));
211 fConst16 = (0.0 - (2.0 / fConst9));
212 fConst17 = (((fConst7 + -1.4142135623730949) / fConst6) + 1.0);
213 fConst18 = (((fConst7 + -0.51763809020504126) / fConst6) + 1.0);
214 fConst19 = (((fConst2 + -1.9318516525781364) / fConst1) + 1.0);
215 double fConst20 = mydsp_faustpower2_f(fConst1);
216 fConst21 = (1.0 / fConst20);
217 fConst22 = (2.0 * (1.0 - fConst21));
218 fConst23 = (((fConst2 + -1.4142135623730949) / fConst1) + 1.0);
219 fConst24 = (((fConst2 + -0.51763809020504126) / fConst1) + 1.0);
220 double fConst25 = std::tan((20106.192982974677 / fConst0));
221 double fConst26 = (1.0 / fConst25);
222 fConst27 = (1.0 / (((fConst26 + 0.51763809020504126) / fConst25) + 1.0));
223 fConst28 = (1.0 / (((fConst26 + 1.4142135623730949) / fConst25) + 1.0));
224 fConst29 = (1.0 / (((fConst26 + 1.9318516525781364) / fConst25) + 1.0));
225 fConst30 = std::sqrt((fConst13 + 0.29999999999999999));
226 fConst31 = (0.0 - (2.0 / fConst20));
227 fConst32 = (((fConst26 + -1.9318516525781364) / fConst25) + 1.0);
228 double fConst33 = mydsp_faustpower2_f(fConst25);
229 fConst34 = (1.0 / fConst33);
230 fConst35 = (2.0 * (1.0 - fConst34));
231 fConst36 = (((fConst26 + -1.4142135623730949) / fConst25) + 1.0);
232 fConst37 = (((fConst26 + -0.51763809020504126) / fConst25) + 1.0);
233 double fConst38 = std::tan((62831.853071795864 / fConst0));
234 double fConst39 = (1.0 / fConst38);
235 fConst40 = (1.0 / (((fConst39 + 0.51763809020504126) / fConst38) + 1.0));
236 fConst41 = (1.0 / (((fConst39 + 1.4142135623730949) / fConst38) + 1.0));
237 fConst42 = (1.0 / (((fConst39 + 1.9318516525781364) / fConst38) + 1.0));
238 fConst43 = (0.13999999999999999 * fConst0);
239 fConst44 = (0.0 - (2.0 / fConst33));
240 fConst45 = (((fConst39 + -1.9318516525781364) / fConst38) + 1.0);
241 fConst46 = (2.0 * (1.0 - (1.0 / mydsp_faustpower2_f(fConst38))));
242 fConst47 = (((fConst39 + -1.4142135623730949) / fConst38) + 1.0);
243 fConst48 = (((fConst39 + -0.51763809020504126) / fConst38) + 1.0);
244 fConst49 = (1.0 / (((fConst7 + 0.76536686473017945) / fConst6) + 1.0));
245 fConst50 = (1.0 / (((fConst7 + 1.8477590650225735) / fConst6) + 1.0));
246 fConst51 = (((fConst7 + -1.8477590650225735) / fConst6) + 1.0);
247 fConst52 = (((fConst7 + -0.76536686473017945) / fConst6) + 1.0);
248 fConst53 = (3.1415926535897931 / fConst0);
249 fConst54 = std::log10((fConst13 + 9.0));
250 fConst55 = std::cos((0.246 * fConst0));
251 IOTA = 0;
252 clear_state_f();
253 }
254
init_static(unsigned int sample_rate,PluginDef * p)255 void Dsp::init_static(unsigned int sample_rate, PluginDef *p)
256 {
257 static_cast<Dsp*>(p)->init(sample_rate);
258 }
259
compute(int count,FAUSTFLOAT * input0,FAUSTFLOAT * input1,FAUSTFLOAT * output0,FAUSTFLOAT * output1)260 void always_inline Dsp::compute(int count, FAUSTFLOAT *input0, FAUSTFLOAT *input1, FAUSTFLOAT *output0, FAUSTFLOAT *output1)
261 {
262 double fSlow0 = double(fHslider0);
263 double fSlow1 = (fConst3 * ((0.40000000000000002 * std::cos((1.23 * fSlow0))) + 0.59999999999999998));
264 double fSlow2 = (0.0010000000000000009 * double(fHslider1));
265 double fSlow3 = ((0.27999999999999997 * fSlow0) + 0.59999999999999998);
266 double fSlow4 = (fConst27 * fSlow3);
267 double fSlow5 = ((0.40000000000000002 * std::sin((3.1400000000000001 * fSlow0))) + 0.59999999999999998);
268 double fSlow6 = (fConst40 * fSlow5);
269 double fSlow7 = (1500.0 * fSlow0);
270 double fSlow8 = std::tan((fConst53 * (20000.0 - fSlow7)));
271 double fSlow9 = (1.0 / fSlow8);
272 double fSlow10 = (((fSlow9 + 0.51763809020504126) / fSlow8) + 1.0);
273 double fSlow11 = (fSlow3 / fSlow10);
274 double fSlow12 = (1.0 / (((fSlow9 + 1.4142135623730949) / fSlow8) + 1.0));
275 double fSlow13 = (1.0 / (((fSlow9 + 1.9318516525781364) / fSlow8) + 1.0));
276 double fSlow14 = std::tan((fConst53 * (6400.0 - fSlow7)));
277 double fSlow15 = (1.0 / fSlow14);
278 double fSlow16 = (((fSlow15 + 0.51763809020504126) / fSlow14) + 1.0);
279 double fSlow17 = (1.0 / fSlow16);
280 double fSlow18 = mydsp_faustpower2_f(fSlow14);
281 double fSlow19 = (1.0 / fSlow18);
282 double fSlow20 = (1.0 / (((fSlow15 + 1.4142135623730949) / fSlow14) + 1.0));
283 double fSlow21 = (1.0 / (((fSlow15 + 1.9318516525781364) / fSlow14) + 1.0));
284 double fSlow22 = (((fSlow15 + -1.9318516525781364) / fSlow14) + 1.0);
285 double fSlow23 = (2.0 * (1.0 - fSlow19));
286 double fSlow24 = (0.0 - (2.0 / fSlow18));
287 double fSlow25 = (((fSlow15 + -1.4142135623730949) / fSlow14) + 1.0);
288 double fSlow26 = (((fSlow15 + -0.51763809020504126) / fSlow14) + 1.0);
289 double fSlow27 = (((fSlow9 + -1.9318516525781364) / fSlow8) + 1.0);
290 double fSlow28 = (2.0 * (1.0 - (1.0 / mydsp_faustpower2_f(fSlow8))));
291 double fSlow29 = (((fSlow9 + -1.4142135623730949) / fSlow8) + 1.0);
292 double fSlow30 = (1.0 / fSlow10);
293 double fSlow31 = (((fSlow9 + -0.51763809020504126) / fSlow8) + 1.0);
294 double fSlow32 = (fSlow5 / fSlow16);
295 double fSlow33 = std::tan((fConst53 * (3600.0 - fSlow7)));
296 double fSlow34 = (1.0 / fSlow33);
297 double fSlow35 = (((fSlow34 + 0.51763809020504126) / fSlow33) + 1.0);
298 double fSlow36 = (1.0 / fSlow35);
299 double fSlow37 = mydsp_faustpower2_f(fSlow33);
300 double fSlow38 = (1.0 / fSlow37);
301 double fSlow39 = (1.0 / (((fSlow34 + 1.4142135623730949) / fSlow33) + 1.0));
302 double fSlow40 = (1.0 / (((fSlow34 + 1.9318516525781364) / fSlow33) + 1.0));
303 double fSlow41 = (((fSlow34 + -1.9318516525781364) / fSlow33) + 1.0);
304 double fSlow42 = (2.0 * (1.0 - fSlow38));
305 double fSlow43 = (0.0 - (2.0 / fSlow37));
306 double fSlow44 = (((fSlow34 + -1.4142135623730949) / fSlow33) + 1.0);
307 double fSlow45 = (((fSlow34 + -0.51763809020504126) / fSlow33) + 1.0);
308 double fSlow46 = (((0.40000000000000002 * std::sqrt((fSlow0 + 0.29999999999999999))) + 0.59999999999999998) / fSlow35);
309 double fSlow47 = std::tan((fConst53 * (1800.0 - fSlow7)));
310 double fSlow48 = (1.0 / fSlow47);
311 double fSlow49 = (1.0 / (((fSlow48 + 0.51763809020504126) / fSlow47) + 1.0));
312 double fSlow50 = mydsp_faustpower2_f(fSlow47);
313 double fSlow51 = (1.0 / fSlow50);
314 double fSlow52 = (1.0 / (((fSlow48 + 1.4142135623730949) / fSlow47) + 1.0));
315 double fSlow53 = (1.0 / (((fSlow48 + 1.9318516525781364) / fSlow47) + 1.0));
316 double fSlow54 = (((fSlow48 + -1.9318516525781364) / fSlow47) + 1.0);
317 double fSlow55 = (2.0 * (1.0 - fSlow51));
318 double fSlow56 = (0.0 - (2.0 / fSlow50));
319 double fSlow57 = (((fSlow48 + -1.4142135623730949) / fSlow47) + 1.0);
320 double fSlow58 = (((fSlow48 + -0.51763809020504126) / fSlow47) + 1.0);
321 for (int i0 = 0; (i0 < count); i0 = (i0 + 1)) {
322 double fTemp0 = double(input0[i0]);
323 fVec0[(IOTA & 131071)] = fTemp0;
324 fRec6[0] = (fSlow2 + (0.999 * fRec6[1]));
325 double fTemp1 = (fConst13 * fRec6[0]);
326 int iTemp2 = int(fTemp1);
327 int iTemp3 = std::min<int>(65537, std::max<int>(0, iTemp2));
328 double fTemp4 = std::floor(fTemp1);
329 double fTemp5 = (fTemp4 + (1.0 - fTemp1));
330 double fTemp6 = (fTemp1 - fTemp4);
331 int iTemp7 = std::min<int>(65537, std::max<int>(0, (iTemp2 + 1)));
332 fRec5[0] = (((fVec0[((IOTA - iTemp3) & 131071)] * fTemp5) + (fTemp6 * fVec0[((IOTA - iTemp7) & 131071)])) - (fConst12 * ((fConst14 * fRec5[2]) + (fConst15 * fRec5[1]))));
333 fRec4[0] = ((fConst12 * (((fConst10 * fRec5[0]) + (fConst16 * fRec5[1])) + (fConst10 * fRec5[2]))) - (fConst11 * ((fConst17 * fRec4[2]) + (fConst15 * fRec4[1]))));
334 fRec3[0] = ((fConst11 * (((fConst10 * fRec4[0]) + (fConst16 * fRec4[1])) + (fConst10 * fRec4[2]))) - (fConst8 * ((fConst18 * fRec3[2]) + (fConst15 * fRec3[1]))));
335 fRec2[0] = ((fConst8 * (((fConst10 * fRec3[0]) + (fConst16 * fRec3[1])) + (fConst10 * fRec3[2]))) - (fConst5 * ((fConst19 * fRec2[2]) + (fConst22 * fRec2[1]))));
336 fRec1[0] = ((fConst5 * (fRec2[2] + (fRec2[0] + (2.0 * fRec2[1])))) - (fConst4 * ((fConst23 * fRec1[2]) + (fConst22 * fRec1[1]))));
337 fRec0[0] = ((fConst4 * (fRec1[2] + (fRec1[0] + (2.0 * fRec1[1])))) - (fConst3 * ((fConst24 * fRec0[2]) + (fConst22 * fRec0[1]))));
338 double fTemp8 = (fConst30 * fRec6[0]);
339 int iTemp9 = int(fTemp8);
340 double fTemp10 = std::floor(fTemp8);
341 fRec12[0] = (((fVec0[((IOTA - std::min<int>(65537, std::max<int>(0, iTemp9))) & 131071)] * (fTemp10 + (1.0 - fTemp8))) + ((fTemp8 - fTemp10) * fVec0[((IOTA - std::min<int>(65537, std::max<int>(0, (iTemp9 + 1)))) & 131071)])) - (fConst5 * ((fConst19 * fRec12[2]) + (fConst22 * fRec12[1]))));
342 fRec11[0] = ((fConst5 * (((fConst21 * fRec12[0]) + (fConst31 * fRec12[1])) + (fConst21 * fRec12[2]))) - (fConst4 * ((fConst23 * fRec11[2]) + (fConst22 * fRec11[1]))));
343 fRec10[0] = ((fConst4 * (((fConst21 * fRec11[0]) + (fConst31 * fRec11[1])) + (fConst21 * fRec11[2]))) - (fConst3 * ((fConst24 * fRec10[2]) + (fConst22 * fRec10[1]))));
344 fRec9[0] = ((fConst3 * (((fConst21 * fRec10[0]) + (fConst31 * fRec10[1])) + (fConst21 * fRec10[2]))) - (fConst29 * ((fConst32 * fRec9[2]) + (fConst35 * fRec9[1]))));
345 fRec8[0] = ((fConst29 * (fRec9[2] + (fRec9[0] + (2.0 * fRec9[1])))) - (fConst28 * ((fConst36 * fRec8[2]) + (fConst35 * fRec8[1]))));
346 fRec7[0] = ((fConst28 * (fRec8[2] + (fRec8[0] + (2.0 * fRec8[1])))) - (fConst27 * ((fConst37 * fRec7[2]) + (fConst35 * fRec7[1]))));
347 double fTemp11 = (fConst43 * fRec6[0]);
348 int iTemp12 = int(fTemp11);
349 double fTemp13 = std::floor(fTemp11);
350 fRec18[0] = (((fVec0[((IOTA - std::min<int>(65537, std::max<int>(0, iTemp12))) & 131071)] * (fTemp13 + (1.0 - fTemp11))) + ((fTemp11 - fTemp13) * fVec0[((IOTA - std::min<int>(65537, std::max<int>(0, (iTemp12 + 1)))) & 131071)])) - (fConst29 * ((fConst32 * fRec18[2]) + (fConst35 * fRec18[1]))));
351 fRec17[0] = ((fConst29 * (((fConst34 * fRec18[0]) + (fConst44 * fRec18[1])) + (fConst34 * fRec18[2]))) - (fConst28 * ((fConst36 * fRec17[2]) + (fConst35 * fRec17[1]))));
352 fRec16[0] = ((fConst28 * (((fConst34 * fRec17[0]) + (fConst44 * fRec17[1])) + (fConst34 * fRec17[2]))) - (fConst27 * ((fConst37 * fRec16[2]) + (fConst35 * fRec16[1]))));
353 fRec15[0] = ((fConst27 * (((fConst34 * fRec16[0]) + (fConst44 * fRec16[1])) + (fConst34 * fRec16[2]))) - (fConst42 * ((fConst45 * fRec15[2]) + (fConst46 * fRec15[1]))));
354 fRec14[0] = ((fConst42 * (fRec15[2] + (fRec15[0] + (2.0 * fRec15[1])))) - (fConst41 * ((fConst47 * fRec14[2]) + (fConst46 * fRec14[1]))));
355 fRec13[0] = ((fConst41 * (fRec14[2] + (fRec14[0] + (2.0 * fRec14[1])))) - (fConst40 * ((fConst48 * fRec13[2]) + (fConst46 * fRec13[1]))));
356 double fTemp14 = double(input1[i0]);
357 fVec1[(IOTA & 131071)] = fTemp14;
358 fRec20[0] = ((0.5 * (fTemp0 + fTemp14)) - (fConst50 * ((fConst51 * fRec20[2]) + (fConst15 * fRec20[1]))));
359 fRec19[0] = ((fConst50 * (fRec20[2] + (fRec20[0] + (2.0 * fRec20[1])))) - (fConst49 * ((fConst52 * fRec19[2]) + (fConst15 * fRec19[1]))));
360 double fTemp15 = (fConst49 * (fRec19[2] + (fRec19[0] + (2.0 * fRec19[1]))));
361 output0[i0] = FAUSTFLOAT(((((fSlow1 * (fRec0[2] + (fRec0[0] + (2.0 * fRec0[1])))) + (fSlow4 * (fRec7[2] + (fRec7[0] + (2.0 * fRec7[1]))))) + (fSlow6 * (fRec13[2] + (fRec13[0] + (2.0 * fRec13[1]))))) + fTemp15));
362 double fTemp16 = (fConst54 * fRec6[0]);
363 int iTemp17 = int(fTemp16);
364 double fTemp18 = std::floor(fTemp16);
365 fRec26[0] = (((fVec1[((IOTA - std::min<int>(65537, std::max<int>(0, iTemp17))) & 131071)] * (fTemp18 + (1.0 - fTemp16))) + ((fTemp16 - fTemp18) * fVec1[((IOTA - std::min<int>(65537, std::max<int>(0, (iTemp17 + 1)))) & 131071)])) - (fSlow21 * ((fSlow22 * fRec26[2]) + (fSlow23 * fRec26[1]))));
366 fRec25[0] = ((fSlow21 * (((fSlow19 * fRec26[0]) + (fSlow24 * fRec26[1])) + (fSlow19 * fRec26[2]))) - (fSlow20 * ((fSlow25 * fRec25[2]) + (fSlow23 * fRec25[1]))));
367 fRec24[0] = ((fSlow20 * (((fSlow19 * fRec25[0]) + (fSlow24 * fRec25[1])) + (fSlow19 * fRec25[2]))) - (fSlow17 * ((fSlow26 * fRec24[2]) + (fSlow23 * fRec24[1]))));
368 fRec23[0] = ((fSlow17 * (((fSlow19 * fRec24[0]) + (fSlow24 * fRec24[1])) + (fSlow19 * fRec24[2]))) - (fSlow13 * ((fSlow27 * fRec23[2]) + (fSlow28 * fRec23[1]))));
369 fRec22[0] = ((fSlow13 * (fRec23[2] + (fRec23[0] + (2.0 * fRec23[1])))) - (fSlow12 * ((fSlow29 * fRec22[2]) + (fSlow28 * fRec22[1]))));
370 fRec21[0] = ((fSlow12 * (fRec22[2] + (fRec22[0] + (2.0 * fRec22[1])))) - (fSlow30 * ((fSlow31 * fRec21[2]) + (fSlow28 * fRec21[1]))));
371 fRec32[0] = (((fVec1[((IOTA - iTemp3) & 131071)] * fTemp5) + (fTemp6 * fVec1[((IOTA - iTemp7) & 131071)])) - (fSlow40 * ((fSlow41 * fRec32[2]) + (fSlow42 * fRec32[1]))));
372 fRec31[0] = ((fSlow40 * (((fSlow38 * fRec32[0]) + (fSlow43 * fRec32[1])) + (fSlow38 * fRec32[2]))) - (fSlow39 * ((fSlow44 * fRec31[2]) + (fSlow42 * fRec31[1]))));
373 fRec30[0] = ((fSlow39 * (((fSlow38 * fRec31[0]) + (fSlow43 * fRec31[1])) + (fSlow38 * fRec31[2]))) - (fSlow36 * ((fSlow45 * fRec30[2]) + (fSlow42 * fRec30[1]))));
374 fRec29[0] = ((fSlow36 * (((fSlow38 * fRec30[0]) + (fSlow43 * fRec30[1])) + (fSlow38 * fRec30[2]))) - (fSlow21 * ((fSlow22 * fRec29[2]) + (fSlow23 * fRec29[1]))));
375 fRec28[0] = ((fSlow21 * (fRec29[2] + (fRec29[0] + (2.0 * fRec29[1])))) - (fSlow20 * ((fSlow25 * fRec28[2]) + (fSlow23 * fRec28[1]))));
376 fRec27[0] = ((fSlow20 * (fRec28[2] + (fRec28[0] + (2.0 * fRec28[1])))) - (fSlow17 * ((fSlow26 * fRec27[2]) + (fSlow23 * fRec27[1]))));
377 double fTemp19 = (fConst55 * fRec6[0]);
378 int iTemp20 = int(fTemp19);
379 double fTemp21 = std::floor(fTemp19);
380 fRec38[0] = (((fVec1[((IOTA - std::min<int>(65537, std::max<int>(0, iTemp20))) & 131071)] * (fTemp21 + (1.0 - fTemp19))) + ((fTemp19 - fTemp21) * fVec1[((IOTA - std::min<int>(65537, std::max<int>(0, (iTemp20 + 1)))) & 131071)])) - (fSlow53 * ((fSlow54 * fRec38[2]) + (fSlow55 * fRec38[1]))));
381 fRec37[0] = ((fSlow53 * (((fSlow51 * fRec38[0]) + (fSlow56 * fRec38[1])) + (fSlow51 * fRec38[2]))) - (fSlow52 * ((fSlow57 * fRec37[2]) + (fSlow55 * fRec37[1]))));
382 fRec36[0] = ((fSlow52 * (((fSlow51 * fRec37[0]) + (fSlow56 * fRec37[1])) + (fSlow51 * fRec37[2]))) - (fSlow49 * ((fSlow58 * fRec36[2]) + (fSlow55 * fRec36[1]))));
383 fRec35[0] = ((fSlow49 * (((fSlow51 * fRec36[0]) + (fSlow56 * fRec36[1])) + (fSlow51 * fRec36[2]))) - (fSlow40 * ((fSlow41 * fRec35[2]) + (fSlow42 * fRec35[1]))));
384 fRec34[0] = ((fSlow40 * (fRec35[2] + (fRec35[0] + (2.0 * fRec35[1])))) - (fSlow39 * ((fSlow44 * fRec34[2]) + (fSlow42 * fRec34[1]))));
385 fRec33[0] = ((fSlow39 * (fRec34[2] + (fRec34[0] + (2.0 * fRec34[1])))) - (fSlow36 * ((fSlow45 * fRec33[2]) + (fSlow42 * fRec33[1]))));
386 output1[i0] = FAUSTFLOAT(((fSlow11 * (fRec21[2] + (fRec21[0] + (2.0 * fRec21[1])))) + ((fSlow32 * (fRec27[2] + (fRec27[0] + (2.0 * fRec27[1])))) + (fTemp15 + (fSlow46 * (fRec33[2] + (fRec33[0] + (2.0 * fRec33[1]))))))));
387 IOTA = (IOTA + 1);
388 fRec6[1] = fRec6[0];
389 fRec5[2] = fRec5[1];
390 fRec5[1] = fRec5[0];
391 fRec4[2] = fRec4[1];
392 fRec4[1] = fRec4[0];
393 fRec3[2] = fRec3[1];
394 fRec3[1] = fRec3[0];
395 fRec2[2] = fRec2[1];
396 fRec2[1] = fRec2[0];
397 fRec1[2] = fRec1[1];
398 fRec1[1] = fRec1[0];
399 fRec0[2] = fRec0[1];
400 fRec0[1] = fRec0[0];
401 fRec12[2] = fRec12[1];
402 fRec12[1] = fRec12[0];
403 fRec11[2] = fRec11[1];
404 fRec11[1] = fRec11[0];
405 fRec10[2] = fRec10[1];
406 fRec10[1] = fRec10[0];
407 fRec9[2] = fRec9[1];
408 fRec9[1] = fRec9[0];
409 fRec8[2] = fRec8[1];
410 fRec8[1] = fRec8[0];
411 fRec7[2] = fRec7[1];
412 fRec7[1] = fRec7[0];
413 fRec18[2] = fRec18[1];
414 fRec18[1] = fRec18[0];
415 fRec17[2] = fRec17[1];
416 fRec17[1] = fRec17[0];
417 fRec16[2] = fRec16[1];
418 fRec16[1] = fRec16[0];
419 fRec15[2] = fRec15[1];
420 fRec15[1] = fRec15[0];
421 fRec14[2] = fRec14[1];
422 fRec14[1] = fRec14[0];
423 fRec13[2] = fRec13[1];
424 fRec13[1] = fRec13[0];
425 fRec20[2] = fRec20[1];
426 fRec20[1] = fRec20[0];
427 fRec19[2] = fRec19[1];
428 fRec19[1] = fRec19[0];
429 fRec26[2] = fRec26[1];
430 fRec26[1] = fRec26[0];
431 fRec25[2] = fRec25[1];
432 fRec25[1] = fRec25[0];
433 fRec24[2] = fRec24[1];
434 fRec24[1] = fRec24[0];
435 fRec23[2] = fRec23[1];
436 fRec23[1] = fRec23[0];
437 fRec22[2] = fRec22[1];
438 fRec22[1] = fRec22[0];
439 fRec21[2] = fRec21[1];
440 fRec21[1] = fRec21[0];
441 fRec32[2] = fRec32[1];
442 fRec32[1] = fRec32[0];
443 fRec31[2] = fRec31[1];
444 fRec31[1] = fRec31[0];
445 fRec30[2] = fRec30[1];
446 fRec30[1] = fRec30[0];
447 fRec29[2] = fRec29[1];
448 fRec29[1] = fRec29[0];
449 fRec28[2] = fRec28[1];
450 fRec28[1] = fRec28[0];
451 fRec27[2] = fRec27[1];
452 fRec27[1] = fRec27[0];
453 fRec38[2] = fRec38[1];
454 fRec38[1] = fRec38[0];
455 fRec37[2] = fRec37[1];
456 fRec37[1] = fRec37[0];
457 fRec36[2] = fRec36[1];
458 fRec36[1] = fRec36[0];
459 fRec35[2] = fRec35[1];
460 fRec35[1] = fRec35[0];
461 fRec34[2] = fRec34[1];
462 fRec34[1] = fRec34[0];
463 fRec33[2] = fRec33[1];
464 fRec33[1] = fRec33[0];
465 }
466 }
467
compute_static(int count,FAUSTFLOAT * input0,FAUSTFLOAT * input1,FAUSTFLOAT * output0,FAUSTFLOAT * output1,PluginDef * p)468 void __rt_func Dsp::compute_static(int count, FAUSTFLOAT *input0, FAUSTFLOAT *input1, FAUSTFLOAT *output0, FAUSTFLOAT *output1, PluginDef *p)
469 {
470 static_cast<Dsp*>(p)->compute(count, input0, input1, output0, output1);
471 }
472
register_par(const ParamReg & reg)473 int Dsp::register_par(const ParamReg& reg)
474 {
475 reg.registerFloatVar("panoram_enhancer.Delay width",N_("Delay"),"S",N_("Delay Width"),&fHslider1, 0.0, 0.0, 1.0, 0.01, 0);
476 reg.registerFloatVar("panoram_enhancer.Frequency width",N_("Frequency"),"S",N_("Frequency Width"),&fHslider0, 0.0, 0.0, 1.0, 0.01, 0);
477 return 0;
478 }
479
register_params_static(const ParamReg & reg)480 int Dsp::register_params_static(const ParamReg& reg)
481 {
482 return static_cast<Dsp*>(reg.plugin)->register_par(reg);
483 }
484
485 const char *Dsp::glade_def = "\
486 <?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
487 <!-- Generated with glade 3.22.1 -->\n\
488 <interface>\n\
489 <requires lib=\"gtk+\" version=\"3.20\"/>\n\
490 <requires lib=\"gxwidgets\" version=\"0.0\"/>\n\
491 <object class=\"GtkWindow\" id=\"window1\">\n\
492 <property name=\"can_focus\">False</property>\n\
493 <child>\n\
494 <placeholder/>\n\
495 </child>\n\
496 <child>\n\
497 <object class=\"GtkBox\" id=\"vbox1\">\n\
498 <property name=\"visible\">True</property>\n\
499 <property name=\"can_focus\">False</property>\n\
500 <property name=\"orientation\">vertical</property>\n\
501 <child>\n\
502 <object class=\"GtkBox\" id=\"rackbox\">\n\
503 <property name=\"visible\">True</property>\n\
504 <property name=\"can_focus\">False</property>\n\
505 <property name=\"spacing\">4</property>\n\
506 <child>\n\
507 <object class=\"GtkBox\" id=\"hbox1\">\n\
508 <property name=\"visible\">True</property>\n\
509 <property name=\"can_focus\">False</property>\n\
510 <property name=\"spacing\">10</property>\n\
511 <child>\n\
512 <object class=\"GtkBox\" id=\"vbox2\">\n\
513 <property name=\"visible\">True</property>\n\
514 <property name=\"can_focus\">False</property>\n\
515 <property name=\"orientation\">vertical</property>\n\
516 <child>\n\
517 <object class=\"GtkLabel\" id=\"label1:rack_label\">\n\
518 <property name=\"visible\">True</property>\n\
519 <property name=\"can_focus\">False</property>\n\
520 <property name=\"label\" translatable=\"yes\">label</property>\n\
521 </object>\n\
522 <packing>\n\
523 <property name=\"expand\">False</property>\n\
524 <property name=\"fill\">False</property>\n\
525 <property name=\"position\">0</property>\n\
526 </packing>\n\
527 </child>\n\
528 <child>\n\
529 <object class=\"GxMidKnob\" id=\"gxbigknob1\">\n\
530 <property name=\"visible\">True</property>\n\
531 <property name=\"can_focus\">True</property>\n\
532 <property name=\"receives_default\">True</property>\n\
533 <property name=\"var_id\">panoram_enhancer.Delay width</property>\n\
534 <property name=\"label_ref\">label1:rack_label</property>\n\
535 </object>\n\
536 <packing>\n\
537 <property name=\"expand\">False</property>\n\
538 <property name=\"fill\">False</property>\n\
539 <property name=\"position\">1</property>\n\
540 </packing>\n\
541 </child>\n\
542 </object>\n\
543 <packing>\n\
544 <property name=\"expand\">False</property>\n\
545 <property name=\"fill\">False</property>\n\
546 <property name=\"position\">0</property>\n\
547 </packing>\n\
548 </child>\n\
549 <child>\n\
550 <object class=\"GtkBox\" id=\"vbox3\">\n\
551 <property name=\"visible\">True</property>\n\
552 <property name=\"can_focus\">False</property>\n\
553 <property name=\"orientation\">vertical</property>\n\
554 <child>\n\
555 <object class=\"GtkLabel\" id=\"label2:rack_label\">\n\
556 <property name=\"visible\">True</property>\n\
557 <property name=\"can_focus\">False</property>\n\
558 <property name=\"label\" translatable=\"yes\">label</property>\n\
559 </object>\n\
560 <packing>\n\
561 <property name=\"expand\">False</property>\n\
562 <property name=\"fill\">False</property>\n\
563 <property name=\"position\">0</property>\n\
564 </packing>\n\
565 </child>\n\
566 <child>\n\
567 <object class=\"GxSmallKnobR\" id=\"gxbigknob2\">\n\
568 <property name=\"visible\">True</property>\n\
569 <property name=\"can_focus\">True</property>\n\
570 <property name=\"receives_default\">True</property>\n\
571 <property name=\"var_id\">panoram_enhancer.Frequency width</property>\n\
572 <property name=\"label_ref\">label2:rack_label</property>\n\
573 </object>\n\
574 <packing>\n\
575 <property name=\"expand\">False</property>\n\
576 <property name=\"fill\">False</property>\n\
577 <property name=\"position\">1</property>\n\
578 </packing>\n\
579 </child>\n\
580 </object>\n\
581 <packing>\n\
582 <property name=\"expand\">False</property>\n\
583 <property name=\"fill\">False</property>\n\
584 <property name=\"position\">1</property>\n\
585 </packing>\n\
586 </child>\n\
587 </object>\n\
588 <packing>\n\
589 <property name=\"expand\">True</property>\n\
590 <property name=\"fill\">False</property>\n\
591 <property name=\"pack_type\">end</property>\n\
592 <property name=\"position\">0</property>\n\
593 </packing>\n\
594 </child>\n\
595 </object>\n\
596 <packing>\n\
597 <property name=\"expand\">True</property>\n\
598 <property name=\"fill\">False</property>\n\
599 <property name=\"position\">0</property>\n\
600 </packing>\n\
601 </child>\n\
602 <child>\n\
603 <object class=\"GtkBox\" id=\"minibox\">\n\
604 <property name=\"visible\">True</property>\n\
605 <property name=\"can_focus\">False</property>\n\
606 <property name=\"spacing\">4</property>\n\
607 <child>\n\
608 <object class=\"GxHSlider\" id=\"gxhslider1\">\n\
609 <property name=\"visible\">True</property>\n\
610 <property name=\"can_focus\">True</property>\n\
611 <property name=\"receives_default\">True</property>\n\
612 <property name=\"round_digits\">0</property>\n\
613 <property name=\"var_id\">panoram_enhancer.Delay width</property>\n\
614 <property name=\"show_value\">False</property>\n\
615 <property name=\"value_position\">right</property>\n\
616 <property name=\"value_xalign\">0.52000000000000002</property>\n\
617 <property name=\"label_ref\">label0:rack_label</property>\n\
618 </object>\n\
619 <packing>\n\
620 <property name=\"expand\">False</property>\n\
621 <property name=\"fill\">False</property>\n\
622 <property name=\"position\">0</property>\n\
623 </packing>\n\
624 </child>\n\
625 <child>\n\
626 <object class=\"GtkLabel\" id=\"label0:rack_label\">\n\
627 <property name=\"visible\">True</property>\n\
628 <property name=\"can_focus\">False</property>\n\
629 <property name=\"label\" translatable=\"yes\">Level</property>\n\
630 <property name=\"xalign\">0</property>\n\
631 </object>\n\
632 <packing>\n\
633 <property name=\"expand\">False</property>\n\
634 <property name=\"fill\">False</property>\n\
635 <property name=\"position\">1</property>\n\
636 </packing>\n\
637 </child>\n\
638 </object>\n\
639 <packing>\n\
640 <property name=\"expand\">True</property>\n\
641 <property name=\"fill\">True</property>\n\
642 <property name=\"position\">1</property>\n\
643 </packing>\n\
644 </child>\n\
645 </object>\n\
646 </child>\n\
647 </object>\n\
648 </interface>\n\
649 ";
650
load_ui_f(const UiBuilder & b,int form)651 inline int Dsp::load_ui_f(const UiBuilder& b, int form)
652 {
653 if (form & UI_FORM_GLADE) {
654 b.load_glade(glade_def);
655 return 0;
656 }
657 if (form & UI_FORM_STACK) {
658 #define PARAM(p) ("panoram_enhancer" "." p)
659 // ----- panoram enhancer
660 b.openHorizontalhideBox("");
661 b.closeBox();
662 b.openVerticalBox("");
663 {
664 b.openHorizontalTableBox("");
665 {
666 b.create_small_rackknob(PARAM("Delay width"), _(" delay width "));
667 b.create_small_rackknob(PARAM("Frequency width"), _(" freq width "));
668 }
669 b.closeBox();
670 }
671 b.closeBox();
672
673
674 #undef PARAM
675 return 0;
676 }
677 return -1;
678 }
679
load_ui_f_static(const UiBuilder & b,int form)680 int Dsp::load_ui_f_static(const UiBuilder& b, int form)
681 {
682 return static_cast<Dsp*>(b.plugin)->load_ui_f(b, form);
683 }
plugin()684 PluginDef *plugin() {
685 return new Dsp();
686 }
687
del_instance(PluginDef * p)688 void Dsp::del_instance(PluginDef *p)
689 {
690 delete static_cast<Dsp*>(p);
691 }
692
693 } // end namespace panoram_enhancer
694