double.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 double real;
  25. #ifdef STARPU_HAVE_FFTW
  26. typedef fftw_complex _fftw_complex;
  27. typedef fftw_plan _fftw_plan;
  28. #endif
  29. #ifdef STARPU_USE_CUDA
  30. typedef cuDoubleComplex _cuComplex;
  31. typedef cufftDoubleComplex _cufftComplex;
  32. #define _cufftExecC2C cufftExecZ2Z
  33. #define _cufftExecR2C cufftExecD2Z
  34. #define _cufftExecC2R cufftExecZ2D
  35. #define _CUFFT_C2C CUFFT_Z2Z
  36. #define _CUFFT_R2C CUFFT_D2Z
  37. #define _CUFFT_C2R CUFFT_Z2D
  38. #define _cuCmul(x,y) cuCmul(x,y)
  39. #endif
  40. #define STARPUFFT(name) starpufft_##name
  41. #define _FFTW(name) fftw_##name
  42. #define TYPE ""