ClGenerators.h 4.0 KB

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