12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- #ifndef MANDEL_MANDEL_H
- #define MANDEL_MANDEL_H
- #include <vector>
- #include <string>
- #include <memory>
- #include "MandelUtil.h"
- #include "Generators.h"
- #include "Hardware.h"
- namespace mnd
- {
- class MandelContext;
- class MandelDevice;
- extern MandelContext initializeContext(void);
- }
- class mnd::MandelDevice
- {
- private:
- friend class MandelContext;
- std::string vendor;
- std::string name;
- std::unique_ptr<Generator> floatGenerator;
- std::unique_ptr<Generator> doubleGenerator;
- std::unique_ptr<Generator> generator128;
- MandelDevice(void);
- public:
- inline const std::string& getVendor(void) const { return vendor; }
- const std::string& getName(void) const;
- Generator* getGeneratorFloat(void) const;
- Generator* getGeneratorDouble(void) const;
- Generator* getGenerator128(void) const;
- };
- class mnd::MandelContext
- {
- private:
- friend MandelContext initializeContext(void);
- CpuInfo cpuInfo;
- std::unique_ptr<Generator> cpuGeneratorFloat;
- std::unique_ptr<Generator> cpuGeneratorDouble;
- std::unique_ptr<Generator> cpuGenerator128;
- std::vector<MandelDevice> devices;
- MandelContext(void);
- std::vector<MandelDevice> createDevices(void);
- public:
- Generator& getDefaultGenerator(void);
- const std::vector<MandelDevice>& getDevices(void);
- Generator& getCpuGeneratorFloat(void);
- Generator& getCpuGeneratorDouble(void);
- Generator& getCpuGenerator128(void);
- const CpuInfo& getCpuInfo(void) const { return cpuInfo; }
- };
- #endif // MANDEL_MANDEL_H
|