-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfft.ss
50 lines (44 loc) · 1.81 KB
/
fft.ss
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
(define 2ipi (* 0+4i (asin 1)))
(numerator (rationalize (/ 15 25) 1/10000))
(define fft
(lambda (x)
(let ([N (vector-length x)])
(let ([W (let ([halfN (div0 N 2)]
[W1 (exp (- (/ 2ipi N)))])
(let ([Ws (make-vector halfN)])
(do ([i 0 (+ i 1)]
[Wi 1.0 (* Wi W1)])
((= i halfN))
(vector-set! Ws i Wi))
(lambda (k)
(if (>= k halfN)
(- (vector-ref Ws (- k halfN)))
(vector-ref Ws k)))))])
(define reverse-ind
(let ([levels (bitwise-length (- N 1))])
(lambda (ind)
(bitwise-reverse-bit-field ind 0 levels))))
(let ([X (list->vector (map (lambda (a)
(vector-ref x (reverse-ind a)))
(iota N)))]
[X-temp (make-vector N)])
(let fft-loop ([X X]
[X-temp X-temp]
[size 2]
[groups (div N 2)])
(if (= groups 0)
X-temp
(do ([i 0 (+ i 1)])
((= i groups) (fft-loop X-temp X (* size 2) (div groups 2)))
(do ([j 0 (+ j 1)])
((= j size))
(vector-set! X-temp
(+ (* i size) j)
(+ (vector-ref X (+ (* i size) j))
(* (vector-ref X (+ (* i size) (mod (+ j (div size 2)) size)))
(W (div (* j 8) size))))))))))))))
(define v
(let ([v (make-vector (expt 2 15))])
(do ([i 0 (+ i 1)])
((= i (expt 2 15)) v)
(vector-set! v i (sin (* i 0.01))))))