sctl.hpp 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. // Scientific Computing Template Library
  2. #ifndef _SCTL_HPP_
  3. #define _SCTL_HPP_
  4. #define SCTL_NAMESPACE sctl
  5. #define SCTL_QUOTEME(x) SCTL_QUOTEME_1(x)
  6. #define SCTL_QUOTEME_1(x) #x
  7. #define SCTL_INCLUDE(x) SCTL_QUOTEME(sctl/x)
  8. // Parameters for memory manager
  9. #define SCTL_MEM_ALIGN 64
  10. #ifndef SCTL_GLOBAL_MEM_BUFF
  11. #define SCTL_GLOBAL_MEM_BUFF 1024LL * 0LL // in MB
  12. #endif
  13. // Profiling parameters
  14. #ifndef SCTL_PROFILE
  15. #define SCTL_PROFILE -1 // Granularity level
  16. #endif
  17. // MPI Wrapper
  18. #include SCTL_INCLUDE(comm.hpp)
  19. // Memory Manager, Iterators
  20. #include SCTL_INCLUDE(mem_mgr.hpp)
  21. // Vector
  22. #include SCTL_INCLUDE(vector.hpp)
  23. // Matrix, Permutation operators
  24. #include SCTL_INCLUDE(matrix.hpp)
  25. // Template vector intrinsics
  26. #include SCTL_INCLUDE(intrin_wrapper.hpp)
  27. // OpenMP merge-sort and scan
  28. #include SCTL_INCLUDE(ompUtils.hpp)
  29. // Parallel solver
  30. #include SCTL_INCLUDE(parallel_solver.hpp)
  31. // Chebyshev basis
  32. #include SCTL_INCLUDE(cheb_utils.hpp)
  33. // Morton
  34. #include SCTL_INCLUDE(morton.hpp)
  35. #include SCTL_INCLUDE(fft_wrapper.hpp)
  36. #include SCTL_INCLUDE(legendre_rule.hpp)
  37. // Profiler
  38. #include SCTL_INCLUDE(profile.hpp)
  39. // Print stack trace
  40. #include SCTL_INCLUDE(stacktrace.h)
  41. const int sgh = SCTL_NAMESPACE::SetSigHandler(); // Set signal handler
  42. #endif //_SCTL_HPP_