//----------------------------------------------------------------------------- // gprop //----------------------------------------------------------------------------- #include // EXIT_SUCCESS EXIT_FAILURE #include // exception #include // cerr cout #include // ifstream #include // string #include // eoParser #include // eoPop #include // eoGenContinue #include // eoProportional #include #include // eoSGA #include "gprop.h" // Chrom eoChromInit eoChromMutation eoChromXover eoChromEvaluator //----------------------------------------------------------------------------- // global variables //----------------------------------------------------------------------------- unsigned in, out, hidden; //----------------------------------------------------------------------------- // parameters //----------------------------------------------------------------------------- eoValueParam pop_size(10, "pop_size", "population size", 'p'); eoValueParam generations(10, "generations", "number of generation", 'g'); eoValueParam mut_rate(0.1, "mut_rate", "mutation rate", 'm'); eoValueParam xover_rate(0.1, "xover_rate", "default crossover rate", 'x'); eoValueParam file("", "file", "common start of patterns filenames *.trn *.val and *.tst", 'f'); eoValueParam hiddenp(0, "hidden", "number of neurons in hidden layer", 'd'); //----------------------------------------------------------------------------- // auxiliar functions //----------------------------------------------------------------------------- void arg(int argc, char** argv); void load_file(mlp::set& s, const string& s); 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(file, "files"); parser.processParam(hiddenp, "genetic operators"); if (parser.userNeedsHelp()) { parser.printHelp(cout); exit(EXIT_SUCCESS); } load_file(trn_set, "trn"); load_file(val_set, "val"); load_file(tst_set, "tst"); phenotype::trn_max = trn_set.size(); phenotype::val_max = val_set.size(); phenotype::tst_max = tst_set.size(); in = trn_set.front().input.size(); out = trn_set.front().output.size(); hidden = hiddenp.value(); cout << trn_set << endl; cout << in << " " << out << " " << hidden << endl; } //----------------------------------------------------------------------------- void load_file(mlp::set& set, const string& ext) { string filename = file.value(); filename += "." + ext; ifstream ifs(filename.c_str()); if (!ifs) { cerr << "can't open file \"" << filename << "\"" << endl; exit(EXIT_FAILURE); } ifs >> set; if (set.size() == 0) { cerr << filename << " data file is empty!"; exit(EXIT_FAILURE); } } //----------------------------------------------------------------------------- void ga() { eoGenContinue continuator(generations.value()); // create population eoInitChrom init; eoPop pop(pop_size.value(), init); // evaluate population eoEvalFuncPtr evaluator(eoChromEvaluator); apply(evaluator, pop); // selector // eoProportional select(pop); eoStochTournament select; // genetic operators eoChromMutation mutation(generations); eoChromXover xover; // genetic algorithm eoSGA sga(select, xover, xover_rate.value(), mutation, mut_rate.value(), evaluator, continuator); cout << pop << endl; sga(pop); cout << pop << endl; } //----------------------------------------------------------------------------- // Local Variables: // mode:C++ // End: