X-Git-Url: https://scm.cri.minesparis.psl.eu/git/Faustine.git/blobdiff_plain/043c676f59520b93dfacfa0d8d7e1fdd448cd7dc..1878a8448a5a73cbf289306beb5e88ab48561129:/dsp_files/fft.lib.1.tmp.dsp diff --git a/dsp_files/fft.lib.1.tmp.dsp b/dsp_files/fft.lib.1.tmp.dsp deleted file mode 100644 index bc7ceb8..0000000 --- a/dsp_files/fft.lib.1.tmp.dsp +++ /dev/null @@ -1,37 +0,0 @@ -/****************************************************************** - * FFT - * Implementation contributed by Remy Muller - *****************************************************************/ - -// bus(n) : n parallel cables -bus(2) = _,_; // avoids a lot of "bus(1)" labels in block diagrams -bus(n) = par(i, n, _); - -// twiddle_mult(n) : n parallel cables - -W(k, n) = 1, (0, ( k, ((2 * PI) / n) : *) : -) : polar_cplx; - -twiddle_mult(k, n) = _, W(k, n) : pcplx_mul; - -// selector(i,n) : select ith cable among n -selector(i,n) = par(j, n, S(i, j)) with { S(i,i) = _; S(i,j) = !; }; - -// interleave(m,n) : interleave m*n cables : x(0), x(m), x(2m), ..., x(1),x(1+m), x(1+2m)... -//interleave(m,n) = bus(m*n) <: par(i, m, par(j, n, selector(i+j*m,m*n))); - -// interleave(row,col) : interleave row*col cables from column order to row order. -// input : x(0), x(1), x(2) ..., x(row*col-1) -// output: x(0+0*row), x(0+1*row), x(0+2*row), ..., x(1+0*row), x(1+1*row), x(1+2*row), ... -interleave(row,col) = bus(row*col) <: par(r, row, par(c, col, selector(r+c*row,row*col))); - -// butterfly(n) : addition then substraction of interleaved signals : -xbutterfly(n) = (bus(n/2), par(k, n/2, twiddle_mult(k, n))) <: interleave(n/2,2), interleave(n/2,2) : par(i, n/2, pcplx_add), par(i, n/2, pcplx_sub); - -//btf_downside(n) = bus(n) : interleave(n/2,2); - -// fft(n) : fft matrix function of size n = 2^k -//fft(2) = butterfly(2); -//fft(n) = butterfly(n) : (fft(n/2) , fft(n/2)); - -xbutterflies(2) = xbutterfly(2); -xbutterflies(n) = (xbutterflies(n/2) , xbutterflies(n/2)) : xbutterfly(n);