1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
//
// Copyright (C) 2020 Gareth Jones, Glysade LLC
//
// @@ All Rights Reserved @@
// This file is part of the RDKit.
// The contents are covered by the terms of the BSD license
// which is included in the file license.txt, found at the root
// of the RDKit source tree.
//
#ifndef GABASE_H_
#define GABASE_H_
#include <memory>
#include "../util/RandomUtil.h"
#include "../util/export.h"
namespace GapeGa {
using namespace GarethUtil;
/*
* Interface to support different GAs. Allows other objects to be able to access
* the main GA class. Some of these objects may not be defined by GAs- in which
* case an exception should be thrown.
*
*/
class GA_EXPORT GaBase {
private:
std::string fileName;
GarethUtil::RandomUtil &rng = RandomUtil::getInstance();
size_t popsize = 100;
double selectionPressure = 1.1;
GaBase(const GaBase &other) = delete;
GaBase &operator=(const GaBase &other) = delete;
public:
GaBase() {};
virtual ~GaBase() {};
double getSelectionPressure() const { return selectionPressure; }
size_t getPopsize() const { return popsize; }
GarethUtil::RandomUtil &getRng() { return rng; }
protected:
void setSelectionPressure(double selectionPressure) {
this->selectionPressure = selectionPressure;
}
void setPopsize(size_t popsize) { this->popsize = popsize; }
};
} // namespace GapeGa
#endif /* GABASE_H_ */
|