/* This file is part of Machina. Copyright 2007-2017 David Robillard Machina is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version. Machina is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with Machina. If not, see . */ #ifndef MACHINA_EVOLVER_HPP #define MACHINA_EVOLVER_HPP #include #include #include #include "eugene/GA.hpp" #include "eugene/Random.hpp" #include "machina/types.hpp" #include "raul/TimeStamp.hpp" #include "Machine.hpp" #include "Schrodinbit.hpp" namespace eugene { template class HybridMutation; } namespace machina { class Problem; class Evolver { public: Evolver(Raul::TimeUnit unit, const std::string& target_midi, SPtr seed); void seed(SPtr parent); bool improvement() { return _improvement; } void start(); void join(); const Machine& best() { return _ga->best(); } typedef eugene::GA MachinaGA; private: void run(); eugene::Random _rng; SPtr _ga; SPtr _problem; float _seed_fitness; Schrodinbit _improvement; std::atomic _exit_flag; std::unique_ptr _thread; }; } // namespace machina #endif // MACHINA_EVOLVER_HPP