2 threadsafe ( including OpenMP )
4 first edition of kissfft.hh the C++ template fft engine
7 Changed memory.h to string.h -- apparently more standard
9 Added openmp extensions. This can have fairly linear speedups for larger FFT sizes.
12 Shrank the real-fft memory footprint. Thanks to Galen Seitz.
14 1.2.6 (Nov 14, 2006) The "thanks to GenArts" release.
15 Added multi-dimensional real-optimized FFT, see tools/kiss_fftndr
16 Thanks go to GenArts, Inc. for sponsoring the development.
18 1.2.5 (June 27, 2006) The "release for no good reason" release.
19 Changed some harmless code to make some compilers' warnings go away.
20 Added some more digits to pi -- why not.
21 Added kiss_fft_next_fast_size() function to help people decide how much to pad.
22 Changed multidimensional test from 8 dimensions to only 3 to avoid testing
23 problems with fixed point (sorry Buckaroo Banzai).
25 1.2.4 (Oct 27, 2005) The "oops, inverse fixed point real fft was borked" release.
26 Fixed scaling bug for inverse fixed point real fft -- also fixed test code that should've been failing.
27 Thanks to Jean-Marc Valin for bug report.
29 Use sys/types.h for more portable types than short,int,long => int16_t,int32_t,int64_t
30 If your system does not have these, you may need to define them -- but at least it breaks in a
31 loud and easily fixable way -- unlike silently using the wrong size type.
33 Hopefully tools/psdpng.c is fixed -- thanks to Steve Kellog for pointing out the weirdness.
35 1.2.3 (June 25, 2005) The "you want to use WHAT as a sample" release.
36 Added ability to use 32 bit fixed point samples -- requires a 64 bit intermediate result, a la 'long long'
38 Added ability to do 4 FFTs in parallel by using SSE SIMD instructions. This is accomplished by
39 using the __m128 (vector of 4 floats) as kiss_fft_scalar. Define USE_SIMD to use this.
41 I know, I know ... this is drifting a bit from the "kiss" principle, but the speed advantages
42 make it worth it for some. Also recent gcc makes it SOO easy to use vectors of 4 floats like a POD type.
44 1.2.2 (May 6, 2005) The Matthew release
45 Replaced fixed point division with multiply&shift. Thanks to Jean-Marc Valin for
46 discussions regarding. Considerable speedup for fixed-point.
48 Corrected overflow protection in real fft routines when using fixed point.
49 Finder's Credit goes to Robert Oschler of robodance for pointing me at the bug.
50 This also led to the CHECK_OVERFLOW_OP macro.
53 compiles cleanly with just about every -W warning flag under the sun
55 reorganized kiss_fft_state so it could be read-only/const. This may be useful for embedded systems
56 that are willing to predeclare twiddle factors, factorization.
58 Fixed C_MUL,S_MUL on 16-bit platforms.
60 tmpbuf will only be allocated if input & output buffers are same
61 scratchbuf will only be allocated for ffts that are not multiples of 2,3,5
63 NOTE: The tmpbuf,scratchbuf changes may require synchronization code for multi-threaded apps.
67 interface change -- cfg object is forward declaration of struct instead of void*
68 This maintains type saftey and lets the compiler warn/error about stupid mistakes.
69 (prompted by suggestion from Erik de Castro Lopo)
71 small speed improvements
73 added psdpng.c -- sample utility that will create png spectrum "waterfalls" from an input file
74 ( not terribly useful yet)
77 minor bug fix -- only affects odd rank, in-place, multi-dimensional FFTs
80 split sample_code/ into test/ and tools/
82 Removed 2-D fft and added N-D fft (arbitrary)
84 modified fftutil.c to allow multi-d FFTs
86 Modified core fft routine to allow an input stride via kiss_fft_stride()
87 (eased support of multi-D ffts)
89 Added fast convolution filtering (FIR filtering using overlap-scrap method, with tail scrap)
91 Add kfc.[ch]: the KISS FFT Cache. It takes care of allocs for you ( suggested by Oscar Lesta ).
94 fixed bug that occurred when nfft==1. Thanks to Steven Johnson.
97 changed kiss_fft function from using a single buffer, to two buffers.
98 If the same buffer pointer is supplied for both in and out, kiss will
99 manage the buffer copies.
101 added kiss_fft2d and kiss_fftr as separate source files (declarations in kiss_fft.h )
103 0.4 :(Nov 4,2003) optimized for radix 2,3,4,5
105 0.3 :(Oct 28, 2003) woops, version 2 didn't actually factor out any radices other than 2.
106 Thanks to Steven Johnson for finding this one.
108 0.2 :(Oct 27, 2003) added mixed radix, only radix 2,4 optimized versions
110 0.1 :(May 19 2003) initial release, radix 2 only