forked from smoge/gxplugins
-
Notifications
You must be signed in to change notification settings - Fork 0
/
gxamp2.dsp
69 lines (58 loc) · 1.88 KB
/
gxamp2.dsp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
declare name "amp-t2";
import("music.lib");
import("filter.lib");
import("effect.lib");
import("guitarix.lib");
/****************************************************************
** Tube Preamp Emulation stage 1 - 2
*/
bifilter = tf2(b0,b1,b2,a1,a2) with
{
c = 1.059;
R = 0.9221;
lc0 = 0.00506158;
lc1 = 0.06446806;
lc2 = 0.27547621;
lc3 = 0.43359433;
lc4 = 1.31282248;
lc5 = 0.07238887;
fc = 1200 : *(2*PI/SR) : log;
p = lc0*pow(fc,5) + lc1*pow(fc,4) + lc2*pow(fc,3) + lc3*pow(fc,2) + lc4*fc + lc5 : exp;
//b0 = 1;
//b1 = -1.01;
//b2 = 0;
//a1 = -1.84;
//a2 = 0.846416;
b0 = 1;
b1 = -c;
b2 = 0;
a1 = -2*R*cos(p);
a2 = R*R;
};
tubestage(tb,fck,Rk) = tube : hpf with {
lpfk = lowpass1(fck);
Ftube = ffunction(float Ftube2(int,float), "valve.h", "");
vplus = 250.0;
divider = 40;
Rp = 100.0e3;
tube = (+ : Ftube(tb)) ~ (-(vplus) : *(Rk/Rp) : lpfk) : /(divider);
hpf = highpass1(31.0);
};
tubec(preamp,gain1) = hgroup("amp2", hgroup("stage1", stage1) :
hgroup("stage2", stage2)
) with {
stage1 = tubestage(0,86.0,2700.0):
lowpass1(6531.0) : *(preamp) : tubestage(1,132.0,1500.0);
stage2 = lowpass1(6531.0) : *(gain1) : tubestage(1,194.0,820.0);
} ;
tubeax(preamp,gain1) = hgroup("amp2", hgroup("stage1", stage1) :
hgroup("stage2", stage2)
) with {
stage1 = *(preamp): tubestage(0,86.0,2700.0): *(0.77) :
lowpass1(6531.0) : *(preamp) : tubestage(1,132.0,1500.0): *(0.77);
stage2 = lowpass1(6531.0) : *(gain1) : bifilter : tubestage(1,194.0,820.0) : *(0.77);
} ;
process = tubeax(preamp,gain1) with {
preamp = (vslider(".amp2.stage1.Pregain[alias]",0,-20,20,0.1):db2linear : smoothi(0.999));
gain1 = vslider(".amp2.stage2.gain1[alias]", 6, -20.0, 20.0, 0.1) : db2linear : smoothi(0.999);
};