CpuGenerators.h 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. #ifndef MANDEL_CPUGENERATORS_H
  2. #define MANDEL_CPUGENERATORS_H
  3. #include "Generators.h"
  4. namespace mnd
  5. {
  6. enum CpuExtension
  7. {
  8. NONE,
  9. X86_SSE2,
  10. X86_AVX,
  11. X86_AVX_FMA,
  12. ARM_NEON,
  13. };
  14. template<typename T, mnd::CpuExtension ex = mnd::NONE, bool parallel = true>
  15. class CpuGenerator;
  16. }
  17. template<typename T, mnd::CpuExtension ex, bool parallel>
  18. class mnd::CpuGenerator : public Generator
  19. {
  20. public:
  21. inline CpuGenerator(void) :
  22. Generator{ mnd::getPrecision<T>() }
  23. {
  24. }
  25. virtual void generate(const MandelInfo& info, float* data);
  26. };
  27. template<typename T, bool parallel>
  28. class mnd::CpuGenerator<T, mnd::NONE, parallel> : public Generator
  29. {
  30. public:
  31. inline CpuGenerator(void) :
  32. Generator{ mnd::getPrecision<T>() }
  33. {
  34. }
  35. virtual void generate(const MandelInfo& info, float* data);
  36. };
  37. #if defined(__x86_64__) || defined(_M_X64) || defined(__i386) || defined(_M_IX86)
  38. template<bool parallel>
  39. class mnd::CpuGenerator<float, mnd::X86_SSE2, parallel> : public Generator
  40. {
  41. public:
  42. inline CpuGenerator(void) :
  43. Generator{ mnd::getPrecision<T>() }
  44. {
  45. }
  46. virtual void generate(const MandelInfo& info, float* data);
  47. };
  48. template<bool parallel>
  49. class mnd::CpuGenerator<double, mnd::X86_SSE2, parallel> : public Generator
  50. {
  51. public:
  52. inline CpuGenerator(void) :
  53. Generator{ mnd::getPrecision<T>() }
  54. {
  55. }
  56. virtual void generate(const MandelInfo& info, float* data);
  57. };
  58. template<bool parallel>
  59. class mnd::CpuGenerator<float, mnd::X86_AVX, parallel> : public Generator
  60. {
  61. public:
  62. inline CpuGenerator(void) :
  63. Generator{ mnd::getPrecision<T>() }
  64. {
  65. }
  66. virtual void generate(const MandelInfo& info, float* data);
  67. };
  68. template<bool parallel>
  69. class mnd::CpuGenerator<double, mnd::X86_AVX, parallel> : public Generator
  70. {
  71. public:
  72. inline CpuGenerator(void) :
  73. Generator{ mnd::getPrecision<T>() }
  74. {
  75. }
  76. virtual void generate(const MandelInfo& info, float* data);
  77. };
  78. template<bool parallel>
  79. class mnd::CpuGenerator<mnd::DoubleDouble, mnd::X86_AVX, parallel> : public Generator
  80. {
  81. public:
  82. inline CpuGenerator(void) :
  83. Generator{ mnd::getPrecision<T>() }
  84. {
  85. }
  86. virtual void generate(const MandelInfo& info, float* data);
  87. };
  88. #else //if defined(__arm__) || defined(__aarch64__) || defined(_M_ARM)
  89. template<bool parallel>
  90. class mnd::CpuGenerator<float, mnd::ARM_NEON, parallel> : public Generator
  91. {
  92. public:
  93. CpuGenerator(void);
  94. inline CpuGenerator(void) :
  95. Generator{ mnd::getPrecision<float>() }
  96. {
  97. }
  98. virtual void generate(const MandelInfo& info, float* data);
  99. };
  100. template<bool parallel>
  101. class mnd::CpuGenerator<double, mnd::ARM_NEON, parallel> : public Generator
  102. {
  103. public:
  104. inline CpuGenerator(void) :
  105. Generator{ mnd::getPrecision<double>() }
  106. {
  107. }
  108. virtual void generate(const MandelInfo& info, float* data);
  109. };
  110. #endif
  111. template<bool parallel>
  112. class mnd::CpuGenerator<mnd::DoubleDouble, mnd::X86_AVX_FMA, parallel> : public Generator
  113. {
  114. public:
  115. inline CpuGenerator(void) :
  116. Generator{ mnd::getPrecision<DoubleDouble>() }
  117. {
  118. }
  119. virtual void generate(const MandelInfo& info, float* data);
  120. };
  121. #endif // MANDEL_CPUGENERATORS_H