-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathCooleyTukey.m
More file actions
31 lines (31 loc) · 745 Bytes
/
CooleyTukey.m
File metadata and controls
31 lines (31 loc) · 745 Bytes
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
function Output = CooleyTukey(Signal, inv)
N = length(Signal);
if (N == 1)
Output = Signal;
return
end
radix = factor(N);
radix = radix(1);
M = N/radix;
%%
X = zeros(radix, M);
if inv
Sign = 1;
else
Sign = -1;
end
for r = 1:radix
Twiddles = exp(Sign * 2 * pi * 1i * (0:M-1) * (r - 1) / N);
X(r, :) = CooleyTukey(Signal(r:radix:end), inv) .* Twiddles;
end
%%
Output = zeros(1, M);
for k = 0:radix-1
temp = zeros(1, M);
for r = 1:radix
temp_0 = exp(Sign * 2 * pi * 1i * k * M * (r - 1) / N);
temp = temp + temp_0 * X(r, :);
end
Output((k * M + 1):(k * M + M)) = temp;
end
end