/* * PotentialTrainer.hpp * * Created on: Sep 11, 2014 * Author: heber */ #ifndef POTENTIALTRAINER_HPP_ #define POTENTIALTRAINER_HPP_ // include config.h #ifdef HAVE_CONFIG_H #include #endif #include #include #include "Potentials/SerializablePotential.hpp" class element; class HomologyContainer; class HomologyGraph; /** This class is a functor for training a (compound) potential from homologies. * */ class PotentialTrainer { public: PotentialTrainer(); ~PotentialTrainer(); bool operator()( const HomologyContainer &_homologies, const HomologyGraph &_graph, const boost::filesystem::path &_trainingfile, const double _threshold, const unsigned int _best_of_howmany) const; static void storePotentials( const boost::filesystem::path &_potentialfile ); static HomologyGraph getFirstGraphwithSpecifiedElements( const HomologyContainer &homologies, const SerializablePotential::ParticleTypes_t &types); static SerializablePotential::ParticleTypes_t getNumbersFromElements( const std::vector &fragment); }; #endif /* POTENTIALTRAINER_HPP_ */