float.h 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /*
  2. * StarPU
  3. * Copyright (C) Université Bordeaux 1, CNRS 2009 (see AUTHORS file)
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU Lesser General Public License as published by
  7. * the Free Software Foundation; either version 2.1 of the License, or (at
  8. * your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful, but
  11. * WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR in PARTICULAR PURPOSE.
  13. *
  14. * See the GNU Lesser General Public License in COPYING.LGPL for more details.
  15. */
  16. #include <complex.h>
  17. #include <starpu_config.h>
  18. #ifdef STARPU_HAVE_FFTW
  19. #include <fftw3.h>
  20. #endif
  21. #ifdef STARPU_USE_CUDA
  22. #include <cufft.h>
  23. #endif
  24. typedef float real;
  25. #ifdef STARPU_HAVE_FFTW
  26. typedef fftwf_complex _fftw_complex;
  27. typedef fftwf_plan _fftw_plan;
  28. #endif
  29. #ifdef STARPU_USE_CUDA
  30. typedef cuComplex _cuComplex;
  31. typedef cufftComplex _cufftComplex;
  32. #define _cufftExecC2C cufftExecC2C
  33. #define _cufftExecR2C cufftExecR2C
  34. #define _cufftExecC2R cufftExecC2R
  35. #define _CUFFT_C2C CUFFT_C2C
  36. #define _CUFFT_R2C CUFFT_R2C
  37. #define _CUFFT_C2R CUFFT_C2R
  38. #define _cuCmul(x,y) cuCmulf(x,y)
  39. #endif
  40. #define STARPUFFT(name) starpufftf_##name
  41. #define _FFTW(name) fftwf_##name
  42. #define TYPE "f"