//----------------------------------------------------------------------------- // mastermind //----------------------------------------------------------------------------- #include // EXIT_SUCCESS EXIT_FAILURE #include // exception #include // cerr cout #include // ifstream #include // string #include // all usefull eo stuff\ #include "mastermind.h" // Chrom eoChromInit eoChromMutation eoChromXover eoChromEvaluator using namespace std; //----------------------------------------------------------------------------- // global variables //----------------------------------------------------------------------------- unsigned in, out, hidden; //----------------------------------------------------------------------------- // parameters //----------------------------------------------------------------------------- eoValueParam pop_size(16, "pop_size", "population size", 'p'); eoValueParam generations(100, "generations", "number of generation", 'g'); eoValueParam mut_rate(0.1, "mut_rate", "mutation rate", 'm'); eoValueParam xover_rate(0.5, "xover_rate", "default crossover rate", 'x'); eoValueParam col_p(default_colors, "colors", "number of colors", 'c'); eoValueParam len_p(default_length, "legth", "solution legth", 'l'); eoValueParam sol_p(default_solution, "solution", "problem solution", 's'); //----------------------------------------------------------------------------- // auxiliar functions //----------------------------------------------------------------------------- void arg(int argc, char** argv); void ga(); //----------------------------------------------------------------------------- // main //----------------------------------------------------------------------------- int main(int argc, char** argv) { try { arg(argc, argv); ga(); } catch (exception& e) { cerr << argv[0] << ": " << e.what() << endl; exit(EXIT_FAILURE); } return 0; } //----------------------------------------------------------------------------- // implementation //----------------------------------------------------------------------------- void arg(int argc, char** argv) { eoParser parser(argc, argv); parser.processParam(pop_size, "genetic operators"); parser.processParam(generations, "genetic operators"); parser.processParam(mut_rate, "genetic operators"); parser.processParam(xover_rate, "genetic operators"); parser.processParam(col_p, "problem"); parser.processParam(len_p, "problem"); parser.processParam(sol_p, "problem"); if (parser.userNeedsHelp()) { parser.printHelp(cout); exit(EXIT_SUCCESS); } init_eoChromEvaluator(col_p.value(), len_p.value(), sol_p.value()); } //----------------------------------------------------------------------------- void ga() { // create population eoInitChrom init; eoPop pop(pop_size.value(), init); // evaluate population eoEvalFuncPtr evaluator(eoChromEvaluator); apply(evaluator, pop); // selector eoProportionalSelect select(pop); // genetic operators eoChromMutation mutation; eoChromXover xover; // stop condition eoGenContinue continuator1(generations.value()); eoFitContinue continuator2(solution.fitness()); eoCombinedContinue continuator(continuator1, continuator2); // checkpoint eoCheckPoint checkpoint(continuator); // monitor eoStdoutMonitor monitor; checkpoint.add(monitor); // statistics eoBestFitnessStat stats; checkpoint.add(stats); monitor.add(stats); // genetic algorithm eoSGA sga(select, xover, xover_rate.value(), mutation, mut_rate.value(), evaluator, checkpoint); sga(pop); cout << "solution = " << solution << endl << "best = " << *max_element(pop.begin(), pop.end()) << endl; } //----------------------------------------------------------------------------- // Local Variables: // mode:C++ // End: