Giter Site home page Giter Site logo

wtclarke / finufft Goto Github PK

View Code? Open in Web Editor NEW

This project forked from flatironinstitute/finufft

0.0 0.0 0.0 42.32 MB

Non-uniform fast Fourier transform library of types 1,2,3 in dimensions 1,2,3

License: Other

Shell 1.72% C++ 35.87% Python 11.40% C 17.40% Fortran 6.79% MATLAB 7.71% M 0.01% Cuda 15.81% Makefile 1.44% CMake 1.84%

finufft's Introduction

Flatiron Institute Nonuniform Fast Fourier Transform library: FINUFFT

Actions status Read the Docs   Python wrapper: PyPI - Downloads

Principal author Alex H. Barnett ([email protected]), main co-developers Jeremy F. Magland, Ludvig af Klinteberg, Yu-hsuan "Melody" Shih, Libin Lu, Joakim Andén, and Robert Blackwell; see docs/ackn.rst for full list of contributors. ​

This is a lightweight CPU library to compute the three standard types of nonuniform FFT to a specified precision, in one, two, or three dimensions. It is written in C++ with interfaces to C, Fortran, MATLAB/octave, Python, and (in a separate repository) Julia. It now also integrates the GPU CUDA library cuFINUFFT (which currently does all but type 3).

Please see the online documentation which can also be downloaded as a PDF manual, and a project overview. You will also want to see CPU example codes in the directories examples, test, fortran, matlab/test, matlab/examples, python/finufft/test, etc, and GPU examples in examples/cuda, test/cuda, etc.

If you cannot build via cMake, try the makefile. Python users try pip install finufft. See the docs for details. See our GitHub Issues for tips.

If you prefer to read text files, the source to generate the above documentation is in human-readable (mostly .rst) files as follows:

  • docs/install.rst : installation and compilation instructions
  • docs/install_gpu.rst : installation and compilation for GPU (CUDA)
  • docs/dirs.rst : explanation of directories and files in the package
  • docs/math.rst : mathematical definitions
  • docs/cex.rst : example usage from C++/C
  • docs/c.rst : documentation of C++/C function API
  • docs/c_gpu.rst : documentation of C++/C function API for GPU library
  • docs/opts.rst : optional parameters
  • docs/error.rst : error codes
  • docs/trouble.rst : troubleshooting advice
  • docs/tut.rst and tutorial/* : tutorial application examples
  • docs/fortran.rst : usage examples from Fortran, documentation of interface
  • docs/matlab.rst and docs/matlabhelp.raw : using the MATLAB/Octave interface
  • docs/python.rst and python/*/_interfaces.py : using the Python interface
  • docs/python_gpu.rst : Python interface to GPU library
  • docs/julia.rst : information for Julia users
  • docs/devnotes.rst: notes/guide for developers
  • docs/related.rst : other recommended NUFFT packages
  • docs/users.rst : some known users of FINUFFT, dependent packages
  • docs/ackn.rst : authors and acknowledgments
  • docs/refs.rst : journal article references (ours and others)

If you find (cu)FINUFFT useful in your work, please star this repository and cite it and the following. It will help us to improve the library if you also describe your use case parameters here.

For FINUFFT (CPU library):

A parallel non-uniform fast Fourier transform library based on an ``exponential of semicircle'' kernel. A. H. Barnett, J. F. Magland, and L. af Klinteberg. SIAM J. Sci. Comput. 41(5), C479-C504 (2019).

For cuFINUFFT (GPU library):

cuFINUFFT: a load-balanced GPU library for general-purpose nonuniform FFTs, Yu-hsuan Shih, Garrett Wright, Joakim Andén, Johannes Blaschke, Alex H. Barnett, PDSEC2021 workshop of the IPDPS2021 conference. https://arxiv.org/abs/2102.08463

finufft's People

Contributors

ahbarnett avatar melodyshih avatar janden avatar lu1and10 avatar blackwer avatar garrettwrong avatar magland avatar jblaschke avatar diamondinoia avatar wendazhou avatar ludvigak avatar jkrimmer avatar dfm avatar mreineck avatar wardbrian avatar raulppelaez avatar mosco avatar akmalleo3 avatar dylex avatar elliottslaughter avatar hbrunie avatar hugostrand avatar mmuetzel avatar mikael-epigram avatar vineetbansal avatar barracuda156 avatar danfortunato avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.