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