123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- #ifndef MANDEL_MANDEL_H
- #define MANDEL_MANDEL_H
- #include <vector>
- #include <string>
- #include <memory>
- #include "MandelUtil.h"
- #include "Generators.h"
- #include "Hardware.h"
- //#include "Fixedp.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::unique_ptr<Generator> cpuGeneratorFixedp;
- std::unique_ptr<Generator> adaptiveGenerator;
- 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
|