// -*- mode: c++; c-indent-level: 4; c++-member-init-indent: 8; comment-column: 35; -*- //----------------------------------------------------------------------------- // make_continue_moeo.h // (c) OPAC Team (LIFL), Dolphin Project (INRIA), 2007 /* This library... Contact: paradiseo-help@lists.gforge.inria.fr, http://paradiseo.gforge.inria.fr */ //----------------------------------------------------------------------------- #ifndef MAKE_CONTINUE_MOEO_H_ #define MAKE_CONTINUE_MOEO_H_ #include #include #include #include #include #ifndef _MSC_VER #include #endif #include #include /** * Helper function * @param _combined the eoCombinedContinue object * @param _cont the eoContinue to add */ template eoCombinedContinue * make_combinedContinue(eoCombinedContinue *_combined, eoContinue *_cont) { if (_combined) // already exists _combined->add(*_cont); else _combined = new eoCombinedContinue(*_cont); return _combined; } /** * This functions allows to build a eoContinue for multi-objective optimization from the parser (partly taken from make_continue_pareto.h) * @param _parser the parser * @param _state to store allocated objects * @param _eval the funtions evaluator */ template eoContinue & do_make_continue_moeo(eoParser& _parser, eoState& _state, eoEvalFuncCounter & _eval) { // the combined continue - to be filled eoCombinedContinue *continuator = NULL; // First the eoGenContinue - need a default value so you can run blind // but we also need to be able to avoid it <--> 0 eoValueParam& maxGenParam = _parser.createParam((unsigned int)(100), "maxGen", "Maximum number of generations (0 = none)",'G',"Stopping criterion"); if (maxGenParam.value()) // positive: -> define and store { eoGenContinue *genCont = new eoGenContinue(maxGenParam.value()); _state.storeFunctor(genCont); // and "add" to combined continuator = make_combinedContinue(continuator, genCont); } // maxEval eoValueParam& maxEvalParam = _parser.getORcreateParam((unsigned long)(0), "maxEval", "Maximum number of evaluations (0 = none)", 'E', "Stopping criterion"); if (maxEvalParam.value()) { eoEvalContinue *evalCont = new eoEvalContinue(_eval, maxEvalParam.value()); _state.storeFunctor(evalCont); // and "add" to combined continuator = make_combinedContinue(continuator, evalCont); } // maxTime eoValueParam& maxTimeParam = _parser.getORcreateParam((unsigned long)(0), "maxTime", "Maximum running time in seconds (0 = none)", 'T', "Stopping criterion"); if (maxTimeParam.value()) // positive: -> define and store { eoTimeContinue *timeCont = new eoTimeContinue(maxTimeParam.value()); _state.storeFunctor(timeCont); // and "add" to combined continuator = make_combinedContinue(continuator, timeCont); } // CtrlC #ifndef _MSC_VER // the CtrlC interception (Linux only I'm afraid) eoCtrlCContinue *ctrlCCont; eoValueParam& ctrlCParam = _parser.createParam(true, "CtrlC", "Terminate current generation upon Ctrl C",'C', "Stopping criterion"); if (_parser.isItThere(ctrlCParam)) { ctrlCCont = new eoCtrlCContinue; // store _state.storeFunctor(ctrlCCont); // add to combinedContinue continuator = make_combinedContinue(continuator, ctrlCCont); } #endif // now check that there is at least one! if (!continuator) throw std::runtime_error("You MUST provide a stopping criterion"); // OK, it's there: store in the eoState _state.storeFunctor(continuator); // and return return *continuator; } #endif /*MAKE_CONTINUE_MOEO_H_*/