ClGenerators.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. #ifndef MANDEL_CLGENERATORS_H
  2. #define MANDEL_CLGENERATORS_H
  3. #ifdef WITH_OPENCL
  4. #include "Generators.h"
  5. #include "OpenClCode.h"
  6. #include <optional>
  7. #include <vector>
  8. #ifdef __APPLE__
  9. #define CL_TARGET_OPENCL_VERSION 120
  10. #define CL_HPP_TARGET_OPENCL_VERSION 120
  11. #define CL_HPP_MINIMUM_OPENCL_VERSION 120
  12. #else
  13. #define CL_TARGET_OPENCL_VERSION 120
  14. #define CL_HPP_TARGET_OPENCL_VERSION 120
  15. #define CL_HPP_MINIMUM_OPENCL_VERSION 120
  16. #endif
  17. #ifdef WITH_OPENCL
  18. #ifdef __APPLE__
  19. #include <OpenCL/cl.hpp>
  20. #else
  21. #include <CL/cl2.hpp>
  22. #endif
  23. #endif
  24. namespace mnd
  25. {
  26. class MandelDevice;
  27. class ClGenerator;
  28. class ClGeneratorFloat;
  29. class ClGeneratorDoubleFloat;
  30. class ClGeneratorTripleFloat;
  31. class ClGeneratorDouble;
  32. class ClGeneratorDoubleDouble;
  33. class ClGeneratorTripleDouble;
  34. class ClGeneratorQuadDouble;
  35. class ClGeneratorHexDouble;
  36. class ClGeneratorOctaDouble;
  37. class ClGenerator128;
  38. class ClGenerator64;
  39. }
  40. class mnd::ClGenerator : public MandelGenerator
  41. {
  42. protected:
  43. MandelDevice& device;
  44. cl::Context& context;
  45. cl::Program program;
  46. cl::CommandQueue queue;
  47. cl::Kernel kernel;
  48. public:
  49. ClGenerator(MandelDevice& device, const std::string& source, mnd::Precision type);
  50. virtual ~ClGenerator(void);
  51. virtual void generate(const MandelInfo& info, float* data) = 0;
  52. virtual mnd::MandelDevice* getDevice(void);
  53. virtual std::optional<std::vector<char>> getBinary(void);
  54. };
  55. class mnd::ClGeneratorFloat : public ClGenerator
  56. {
  57. bool useVec;
  58. public:
  59. ClGeneratorFloat(MandelDevice& device, const std::string& code = mnd::cl_src::float_cl);
  60. virtual ~ClGeneratorFloat(void) = default;
  61. virtual void generate(const MandelInfo& info, float* data) override;
  62. protected:
  63. virtual std::string getKernelCode(bool smooth) const;
  64. };
  65. class mnd::ClGeneratorDoubleFloat : public ClGenerator
  66. {
  67. public:
  68. ClGeneratorDoubleFloat(MandelDevice& device);
  69. virtual ~ClGeneratorDoubleFloat(void) = default;
  70. virtual void generate(const MandelInfo& info, float* data) override;
  71. protected:
  72. virtual std::string getKernelCode(bool smooth) const;
  73. };
  74. class mnd::ClGeneratorTripleFloat : public ClGenerator
  75. {
  76. public:
  77. ClGeneratorTripleFloat(MandelDevice& device);
  78. virtual ~ClGeneratorTripleFloat(void) = default;
  79. virtual void generate(const MandelInfo& info, float* data) override;
  80. protected:
  81. virtual std::string getKernelCode(bool smooth) const;
  82. };
  83. class mnd::ClGeneratorDouble : public ClGenerator
  84. {
  85. public:
  86. ClGeneratorDouble(mnd::MandelDevice& device, const std::string& source = mnd::cl_src::double_cl);
  87. virtual ~ClGeneratorDouble(void) = default;
  88. virtual void generate(const MandelInfo& info, float* data) override;
  89. };
  90. class mnd::ClGeneratorDoubleDouble : public ClGenerator
  91. {
  92. bool smooth;
  93. public:
  94. ClGeneratorDoubleDouble(mnd::MandelDevice& device, const std::string& source = mnd::cl_src::doubledouble_cl);
  95. virtual ~ClGeneratorDoubleDouble(void) = default;
  96. virtual void generate(const MandelInfo& info, float* data) override;
  97. };
  98. class mnd::ClGeneratorTripleDouble : public ClGenerator
  99. {
  100. bool smooth;
  101. public:
  102. ClGeneratorTripleDouble(mnd::MandelDevice& device);
  103. virtual ~ClGeneratorTripleDouble(void) = default;
  104. virtual void generate(const MandelInfo& info, float* data) override;
  105. protected:
  106. virtual std::string getKernelCode(bool smooth) const;
  107. };
  108. class mnd::ClGeneratorQuadDouble : public ClGenerator
  109. {
  110. bool smooth;
  111. public:
  112. ClGeneratorQuadDouble(mnd::MandelDevice& device, const std::string& source = mnd::cl_src::quaddouble_cl);
  113. virtual ~ClGeneratorQuadDouble(void) = default;
  114. virtual void generate(const MandelInfo& info, float* data) override;
  115. protected:
  116. virtual std::string getKernelCode(bool smooth) const;
  117. };
  118. class mnd::ClGeneratorHexDouble : public ClGenerator
  119. {
  120. public:
  121. ClGeneratorHexDouble(mnd::MandelDevice& device);
  122. virtual ~ClGeneratorHexDouble(void) = default;
  123. virtual void generate(const MandelInfo& info, float* data) override;
  124. protected:
  125. virtual std::string getKernelCode(bool smooth) const;
  126. };
  127. class mnd::ClGeneratorOctaDouble : public ClGenerator
  128. {
  129. public:
  130. ClGeneratorOctaDouble(mnd::MandelDevice& device);
  131. virtual ~ClGeneratorOctaDouble(void) = default;
  132. virtual void generate(const MandelInfo& info, float* data) override;
  133. protected:
  134. virtual std::string getKernelCode(bool smooth) const;
  135. };
  136. class mnd::ClGenerator128 : public ClGenerator
  137. {
  138. public:
  139. ClGenerator128(mnd::MandelDevice& device);
  140. virtual ~ClGenerator128(void) = default;
  141. virtual void generate(const MandelInfo& info, float* data) override;
  142. protected:
  143. virtual std::string getKernelCode(bool smooth) const;
  144. };
  145. class mnd::ClGenerator64 : public ClGenerator
  146. {
  147. public:
  148. ClGenerator64(mnd::MandelDevice& device);
  149. virtual ~ClGenerator64(void) = default;
  150. virtual void generate(const MandelInfo& info, float* data) override;
  151. protected:
  152. virtual std::string getKernelCode(bool smooth) const;
  153. };
  154. #endif // WITH_OPENCL
  155. #endif // MANDEL_CLGENERATORS_H