Skip to content

juanmb/go-fftwf

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Go bindings for FFTW v3.2.2 Maintained by Jonathan Wills: [email protected] Feel free to email me patches, suggestions or bugs.

Adapted to float32 by Juan Menendez: [email protected]

FFTW homepage: http://www.fftw.org/ Documentation for the latest version: http://www.fftw.org/fftw3_doc/

These bindings are incomplete, but should include enough functionality that you can do whatever transforms you need (perhaps not as easily as you would like, for now). The function definitions do not mirror exactly what is written in the docs. For example, passing arrays does not require passing the size of the arrays, and there is no need to garbage collect plans.

Usage: Here is an example of doing a simple DFT with these bindings

data := fftw.Alloc1d(64)  // Similar to calling make([]complex128, 64)
forward  := fftw.PlanDft1d(data, data, fftw.Forward, fftw.Estimate)
backward := fftw.PlanDft1d(data, data, fftw.Backward, fftw.Estimate)
// ... fill in data with something interesting
forward.Execute()  // Transforms data, in place, to frequency domain
// ... do something interesting with data
backward.Execute()  // Returns data, in place, to time domain

Calling fftw.Alloc1d(64) allows FFTW to allocate the memory so that it is properly aligned to take advantage of SIMDs. You could just use make([]complex128, size) if you want.

Installation: When installing fftw you must compile it as a shared library:

./configure --enable-shared
make
make install

Once installed properly, these bindings can be installed like so:

go get github.com/runningwild/go-fftw

About

Go bindings for fftw3

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 100.0%