-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathpyFFT.sql
38 lines (35 loc) · 1.49 KB
/
pyFFT.sql
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
-- Step 1: Create library
CREATE LIBRARY fftTransformFunctions AS '/tmp/pyFFT.py' DEPENDS '/path/to/lib/python3.9/site-packages' LANGUAGE 'Python';
-- Step 2: Create functions
CREATE TRANSFORM FUNCTION pyFFT AS NAME 'pyFFTFactory' LIBRARY fftTransformFunctions;
-- Step 3: Use Functions
-- create a data set of amplitude vs. time
CREATE TABLE t_fft (a FLOAT, b FLOAT);
INSERT INTO t_fft VALUES (0,0);
INSERT INTO t_fft VALUES (0.001,0.141120008);
INSERT INTO t_fft VALUES (0.002,-0.279415498);
INSERT INTO t_fft VALUES (0.003,0.412118485);
INSERT INTO t_fft VALUES (0.004,-0.536572918);
INSERT INTO t_fft VALUES (0.005,0.65028784);
INSERT INTO t_fft VALUES (0.006,-0.750987247);
INSERT INTO t_fft VALUES (0.007,0.836655639);
INSERT INTO t_fft VALUES (0.008,-0.905578362);
INSERT INTO t_fft VALUES (0.009,0.956375928);
INSERT INTO t_fft SELECT a+0.01, 0.0 FROM t_fft;
INSERT INTO t_fft SELECT a+0.02, 0.0 FROM t_fft;
INSERT INTO t_fft SELECT a+0.04, 0.0 FROM t_fft;
INSERT INTO t_fft SELECT a+0.08, 0.0 FROM t_fft;
INSERT INTO t_fft SELECT a+0.16, 0.0 FROM t_fft;
INSERT INTO t_fft SELECT a+0.32, 0.0 FROM t_fft;
INSERT INTO t_fft SELECT a+0.64, 0.0 FROM t_fft;
UPDATE t_fft SET b = sin(40 * 2 * 3.14 * a) + 0.5 * sin(90 * 2 * 3.14 * a);
\timing
\o /dev/null
SELECT * FROM t_fft;
-- Run the FFT and output amplitude vs. frequency
SELECT pyFFT(a, b) OVER() FROM t_fft;
SELECT pyFFT(a, b) OVER() FROM t_fft;
SELECT pyFFT(a, b) OVER() FROM t_fft;
-- Step 4: Clean up
DROP TABLE t_fft;
DROP LIBRARY fftTransformFunctions CASCADE;