-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathphasor.m
117 lines (86 loc) · 2.46 KB
/
phasor.m
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
% Analog phasor described in DAFX
% R < 1 is the radius of each pole in a complex-conjugate pole pair, and the pole angles are ±theta.
% The pole angle theta (0, pi ) can be interpreted as theta = omega*T ,
% where omega is the desired notch frequency and T is the sampling interval.
% The pole radius R controls the width of the notch ? the closer it is to 1,
% the narrower the notch (and the more accurate is the tuning parameter theta).
fs = 44100;
[x,fs] = audioread('highpitchchords.wav');
x = x(:,1);
t = 44100*5; % length of sound in samples
% noise
%x = 2*rand(1,t);
%x = x - mean(x); % remove DC off
out = 0;
signal = 0;
if t > length(x)
diff = t - max(size(x));
x = [x zeros(1,diff)];
end
R1 = 0.4;R2 = .1;R3 = .9;R4 = .61;
theta1 = 440*2*pi/fs; theta2 = 500*2*pi/fs; theta3 = 800*2*pi/fs; theta4 = 100*2*pi/fs;
a11 = -2*R1*cos(theta1);
a21 = R1^2;
a12 = -2*R2*cos(theta2);
a22 = R2^2;
a13 = -2*R3*cos(theta3);
a23 = R3^2;
a14 = -2*R4*cos(theta4);
a24 = R4^2;
AP1 = [0, 0, 0];
AP2 = [0, 0, 0];
AP3 = [0, 0, 0];
AP4 = [0, 0, 0];
xn1 = 0;
xn2 = 0;
wet = 0.5;
dry = 1-wet;
for i = 1:t % t is the iterations
theta1 = (1*2*pi/fs)*i;
if theta1 > 2*pi
theta1 = theta1 - 2*pi;
end
theta2 = (3*2*pi/fs)*i;
if theta2 > 2*pi
theta2 = theta2 - 2*pi;
end
theta3 = (2*2*pi/fs)*i;
if theta3 > 2*pi
theta3 = theta3 - 2*pi;
end
theta4 =(5*2*pi/fs)*i;
if theta4 > 2*pi
theta4 = theta4 - 2*pi;
end
a11 = -2*R1*cos(theta1);
a12 = -2*R2*cos(theta2);
a13 = -2*R3*cos(theta3);
a14 = -2*R4*cos(theta4);
% first allpas
AP1(1) = a21 * x(i) + a11 * xn1 + xn2 - a11 * AP1(2) - a21 * AP1(3);
% second allpas
AP2(1) = a22 * AP1(1)+ a12 * AP1(2) + AP1(3) - a12 * AP2(2) - a22 * AP2(3);
% third allpass
AP3(1) = a23 * AP2(1)+ a13 * AP2(2) + AP2(3) - a13 * AP3(2) - a23 * AP3(3);
% fourth allpass
AP4(1) = a24 * AP3(1)+ a14 * AP3(2) + AP3(3) - a14 * AP4(2) - a24 * AP4(3);
% signal
xn2 = xn1;
xn1 = x(i);
% first allpass
AP1(3) = AP1(2);
AP1(2) = AP1(1);
% second allpass
AP2(3) = AP2(2);
AP2(2) = AP2(1);
% third allpass
AP3(3) = AP3(2);
AP3(2) = AP3(1);
% fourth allpass
AP4(3) = AP4(2);
AP4(2) = AP4(1);
% mix dry signal x(i) with allpass filtered signal AP4(1)
signal = [signal, dry*x(i)+wet*AP4(1)];
end
plot(signal)
soundsc(signal, fs)