亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? control.cpp

?? 蟻群算法用于求解課程表安排問題。在linux下面實現的
?? CPP
字號:
#include "Control.h"Control::Control( int argc, char** argv ) {    // parse the command line options to set all vars    if( ( argc % 2 == 0 ) || ( argc == 1 ) ) {    cerr << "Parse error: Number of command line parameters incorrect\n";    cerr << "Usage:" << endl;    cerr << argv[ 0 ] << " -i InputFile [-o OutputFile] [-n NumberOfTries] [-s RandomSeed] [-t TimeLimit] [-p ProblemType] [-tau0 TAU0] [-alpha ALPHA] [-beta BETA] [-gamma GAMMA] [-rho RHO] [-q0 Q0] [-colonysize COLONYSIZE] [-factor FACTOR] [-fpiter FPITER] [-fpsteps FPSTEPS] [-spsteps SPSTEPS]" << endl;    exit(1);  }    for( int i = 1; i < argc / 2 + 1; i++ ) {    parameters[ argv[ i * 2 - 1 ] ] = argv[ i * 2 ];  }    nrTry = 0;    // check for input parameter    if( parameterExists( "-i") ) {    is = new ifstream( getStringParameter( "-i" ).c_str() );  } else {    cerr << "Error: No input file given, exiting" << endl;    cerr << "Usage:" << endl;    cerr << argv[ 0 ] << " -i InputFile [-o OutputFile] [-n NumberOfTries] [-s RandomSeed] [-t TimeLimit] [-p ProblemType] [-tau0 TAU0] [-alpha ALPHA] [-beta BETA] [-gamma GAMMA] [-rho RHO] [-q0 Q0] [-colonysize COLONYSIZE] [-factor FACTOR] [-fpiter FPITER] [-fpsteps FPSTEPS] [-spsteps SPSTEPS]" << endl;    exit(1);  }    // check for ouput parameter    if( parameterExists( "-o" ) ) {    os = new ofstream( getStringParameter( "-o" ).c_str() );  } else {    cerr << "Warning: No output file given, writing to stdout" << endl;    os = &cout;  }    // check for number of tries parameter    if( parameterExists( "-n" ) ) {    maxTry = getIntParameter( "-n" );    cout << "Max number of tries " << maxTry << endl;  } else {    cerr << "Warning: Number of tries is set to default (10)" << endl;    maxTry = 10; // default number of tries  }    // check for time limit parameter    if( parameterExists( "-t" ) ) {    timeLimit = getDoubleParameter( "-t" );    cout <<"Time limit " << timeLimit << endl;  } else {    cerr << "Warning: Time limit is set to default (90 sec)" << endl;    timeLimit = 90; // default time limit  }    // check for problem instance type parameter for the local search    if( parameterExists( "-p" ) ) {    problemType = getIntParameter( "-p" );    cout <<"Problem instance type " << problemType << endl;  } else {    //cerr << "Warning: The problem instance type is set by default to 1 (easy)" << endl;    problemType = 1; // default problem type  }      // check for maximum steps parameter for the local search    if( parameterExists( "-m" ) ) {    maxSteps = getIntParameter( "-m" );    cout <<"Max number of steps in the local search " << maxSteps << endl;  } else {    //cerr << "Warning: The maximum number of steps for the local search is set by default to 100" << endl;    maxSteps = 100; // default max steps  }    // check for time limit parameter for the local search    if( parameterExists( "-l" ) ) {    LS_limit = getDoubleParameter( "-l" );    cout <<"Local search time limit " << LS_limit << endl;  } else {    cerr << "Warning: The local search time limit is set to default (99999 sec)" << endl;    LS_limit = 99999; // default local search time limit  }    // check for probability parameter for each move in the local search    if( parameterExists( "-p1" ) ) {    prob1 = getDoubleParameter( "-p1" );    cout << "LS move 1 probability " << prob1 <<endl;  } else {    cerr << "Warning: The local search move 1 probability is set to default 1.0" << endl;    prob1 = 1.0; // default local search probability for each move of type 1 to be performed  }    if( parameterExists( "-p2" ) ) {    prob2 = getDoubleParameter( "-p2" );    cout <<"LS move 2 probability " << prob2 << endl;  } else {    cerr << "Warning: The local search move 2 probability is set to default 1.0" << endl;    prob2 = 1.0; // default local search probability for each move to be performed  }    if( parameterExists( "-p3" ) ) {    prob3 = getDoubleParameter( "-p3" );    cout <<"LS move 3 probability " << prob3 <<  endl;  } else {    cerr << "Warning: The local search move 3 probability is set to default 0.0" << endl;    prob3 = 0.0; // default local search probability for each move to be performed  }    // check for random seed    if( parameterExists( "-s" ) ) {    seed = getIntParameter( "-s" );    srand( seed );  } else {    seed = time( NULL );    cerr << "Warning: " << seed << " used as default random seed" << endl;    srand( seed );  }  // EXTRA CODE ADDED TO CONTROL FOR PARSING COMMAND LINE  //  //  if( parameterExists( "-tau0" ) ) {    TAU0 = getDoubleParameter( "-tau0" );    cout <<"TAU0 pheromone value " << TAU0 <<  endl;    }  //  else {  //    TAU0 = 0.5;  //    cerr << "Warning:" << TAU0 << " used as default TAU0 pheromone parameter" << endl;  //  }  if( parameterExists( "-alpha" ) ) {    ALPHA = getDoubleParameter( "-alpha" );    cout << "ALPHA global update value " << ALPHA << endl;  }  //  else {  //    ALPHA = 0.1;  //    cerr << "Warning:" << ALPHA << " used as default ALPHA global update parameter" << endl;  //  }  if( parameterExists( "-beta" ) ) {    BETA = getDoubleParameter( "-beta" );    cout <<"BETA heuristic value " << BETA <<  endl;  }  //  else {  //    BETA = 3.0;  //    cerr << "Warning:" << BETA << " used as default BETA heuristic parameter" << endl;  //  }  if( parameterExists( "-gamma" ) ) {    GAMMA = getDoubleParameter( "-gamma" );    cout <<"GAMMA heuristic value " << GAMMA <<  endl;  }  //  else {  //    GAMMA = 2.0;  //    cerr << "Warning:" << GAMMA << " used as default GAMMA heuristic parameter" << endl;  //  }  if( parameterExists( "-rho" ) ) {    RHO = getDoubleParameter( "-rho" );    cout <<"RHO evaporation value " << RHO <<  endl;  }   //  else {  //    RHO = 0.1;  //      cerr << "Warning:" << RHO << " used as default RHO evaporation parameter" << endl;  //  }  if( parameterExists( "-q0" ) ) {    Q0 = getDoubleParameter( "-q0" );    cout <<"Q0 exploration probability value " << Q0 <<  endl;  }   //  else {  //    Q0 = 0.0;  //    cerr << "Warning:" << Q0 << " used as default QO exploration probability parameter" << endl;  //  }  if( parameterExists( "-colonysize" ) ) {    COLONYSIZE = getIntParameter( "-colonysize" );    cout <<"COLONYSIZE value " << COLONYSIZE <<  endl;  }   //  else {  //    COLONYSIZE = 15;  //    cerr << "Warning:" << COLONYSIZE << " used as default COLONYSIZE parameter" << endl;  //  }  if( parameterExists( "-factor" ) ) {    FACTOR = getDoubleParameter( "-factor" );    cout <<"FACTOR pheromone update value " << FACTOR <<  endl;  }   //  else {  //    FACTOR = 100000.0;  //    cerr << "Warning:" << FACTOR << " used as default FACTOR pheromone global update parameter" << endl;  //  }  if( parameterExists( "-fpiter" ) ) {    FPITER = getIntParameter( "-fpiter" );    cout <<"FPITER local search value " << FPITER <<  endl;  }   //  else {  //    FPITER = 1;  //    cerr << "Warning:" << FPITER << " used as default FPITER first phase number of iterations parameter" << endl;  //  }  if( parameterExists( "-fpsteps" ) ) {    FPSTEPS = getIntParameter( "-fpsteps" );    cout <<"FPSTEPS local search value " << FPSTEPS <<  endl;  }   //  else {  //    FPSTEPS = 5000;  //    cerr << "Warning:" << FPSTEPS << " used as default FPSTEPS first phase number of steps in local search parameter" << endl;  //  }  if( parameterExists( "-spsteps" ) ) {    SPSTEPS = getIntParameter( "-spsteps" );    cout <<"SPSTEPS local search value " << SPSTEPS <<  endl;  }   //  else {  //    SPSTEPS = 2000;  //    cerr << "Warning:" << SPSTEPS << " used as default SPSTEPS second phase number of steps in local search parameter" << endl;  //  }  }Control::~Control() {}boolControl::parameterExists( string paramName ) {	for( map< string, string >::iterator i = parameters.begin(); i != parameters.end(); i++ ) {		if( i-> first == paramName )			return true;	}	return false;}intControl::getIntParameter( string paramName ) {	if( parameterExists( paramName ) )		return atoi( parameters[paramName].c_str() );	else {		return 0;	}}doubleControl::getDoubleParameter( string paramName ) {	if( parameterExists( paramName ) )		return atof( parameters[paramName].c_str() );	else {		return 0;	}}stringControl::getStringParameter( string paramName ) {	if( parameterExists( paramName ) )		return parameters[paramName];	else {		return 0;	}}voidControl::resetTime() {	timer.resetTime();}doubleControl::getTime() {	return timer.elapsedTime( Timer::VIRTUAL );}voidControl::beginTry() {	srand( seed++ );	(*os) << "begin try " << ++nrTry << endl;	resetTime();	feasible = false;	bestScv = INT_MAX;	bestEvaluation = INT_MAX;}voidControl::endTry( Solution *bestSolution) {  (*os) << "begin solution " << nrTry << endl;  if(bestSolution->feasible){    (*os) << "feasible: evaluation function = " << bestSolution->scv <<endl;    for(int i = 0; i < (*bestSolution).data->n_of_events; i++)      (*os) << bestSolution->sln[i].first << " " ;    (*os) << endl;    for(int i = 0; i < (*bestSolution).data->n_of_events; i++)      (*os) << bestSolution->sln[i].second << " " ;    (*os) << endl;  }  else{    (*os) << "unfeasible: evaluation function = " << (bestSolution->computeHcv() * 1000000) + bestSolution->computeScv() <<endl;  }  (*os) << "end solution " << nrTry << endl;  (*os) << "end try " << nrTry << endl;  // The following output might be used if the ./checksln program wants to be used to check the validity of solutions.  // Remember that the output file has then to have the .sln extension and has to have the same name as the .tim instance file  /*for(int i = 0; i < (*bestSolution).data->n_of_events; i++){    (*os) << bestSolution->sln[i].first << " "<< bestSolution->sln[i].second;    (*os) << endl;    }*/}voidControl::setCurrentCost(Solution *currentSolution ) {  //if( timeLeft() ) {	  int currentScv = currentSolution->scv;	  if( currentSolution->feasible && currentScv < bestScv ) {	    bestScv = currentScv;	    bestEvaluation = currentScv;	    double time = getTime();	    (*os) << "best " << bestScv << " time ";			os->flags( ios::fixed );			(*os) << ( time < 0 ? 0.0 : time ) << endl;	  }	  else if(!currentSolution->feasible){ 	    int currentEvaluation = (currentSolution->computeHcv() * 1000000) + currentSolution->computeScv();	    if(currentEvaluation < bestEvaluation){	      bestEvaluation = currentEvaluation;	      double time = getTime();	    (*os) << "best " << bestEvaluation << " time ";			os->flags( ios::fixed );			(*os) << ( time < 0 ? 0.0 : time ) << endl;	    }	  }	  //}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产中文字幕精品| 日韩一区二区精品在线观看| 日本韩国视频一区二区| 欧美一区二区在线免费观看| 久久久久88色偷偷免费| 午夜精品福利视频网站| 成人国产一区二区三区精品| 日韩午夜激情av| 亚洲猫色日本管| 国模娜娜一区二区三区| 欧美精品亚洲二区| 一区二区三区高清| 成人免费高清视频在线观看| 日韩欧美国产1| 亚洲第一二三四区| 91精彩视频在线观看| 亚洲国产精品国自产拍av| 美女任你摸久久 | 91在线视频网址| 欧美变态口味重另类| 午夜精品一区二区三区三上悠亚| 风间由美性色一区二区三区| 欧美va亚洲va| 美女一区二区三区| 日韩精品最新网址| 青青草原综合久久大伊人精品优势| 91尤物视频在线观看| 亚洲国产精品国自产拍av| 国产风韵犹存在线视精品| 精品国产伦一区二区三区观看方式 | 国产成人av电影在线观看| 日韩免费性生活视频播放| 婷婷国产在线综合| 欧美男同性恋视频网站| 亚洲第一电影网| 91精品免费在线观看| 免费成人美女在线观看| 欧美电影一区二区| 蜜臀av一级做a爰片久久| 精品国产网站在线观看| 国产美女一区二区三区| 欧美经典一区二区| 91丨九色丨蝌蚪丨老版| 亚洲精品五月天| 欧美日韩国产三级| 美脚の诱脚舐め脚责91| 久久久久久久网| 成人av网址在线| 亚洲免费av观看| 欧美精品日韩精品| 九九国产精品视频| 国产精品美女一区二区三区| 99在线视频精品| 亚瑟在线精品视频| 精品美女一区二区| 成人av在线观| 午夜欧美视频在线观看 | 精品视频在线视频| 日韩国产精品久久久| 久久综合资源网| 91一区二区在线| 欧美aⅴ一区二区三区视频| 国产亚洲欧美中文| 色国产精品一区在线观看| 婷婷六月综合网| 欧美激情在线观看视频免费| 在线免费一区三区| 国内精品久久久久影院色 | 日韩黄色免费电影| 欧美极品aⅴ影院| 欧美日韩精品一区视频| 国产精品一区二区无线| 亚洲激情自拍偷拍| 久久看人人爽人人| 欧美日韩国产天堂| 91影院在线免费观看| 精品一区二区影视| 一区二区三区波多野结衣在线观看| 日韩欧美一级片| 色综合久久天天综合网| 精品中文字幕一区二区| 亚洲精品你懂的| 欧美激情一区不卡| 日韩欧美成人午夜| 在线亚洲一区观看| 成人午夜激情在线| 老司机午夜精品99久久| 亚洲一区二区免费视频| 国产欧美精品一区二区色综合| 欧美久久久影院| 色94色欧美sute亚洲线路一久| 国产精品18久久久久久久久久久久 | 91精品婷婷国产综合久久| 99国产一区二区三精品乱码| 久久国内精品自在自线400部| 亚洲永久免费视频| 成人欧美一区二区三区| 久久精品夜色噜噜亚洲aⅴ| 51精品秘密在线观看| 欧美在线高清视频| 色诱视频网站一区| 99国产精品一区| 成人激情免费电影网址| 国产成人在线视频免费播放| 麻豆国产一区二区| 人人精品人人爱| 日本91福利区| 免费在线看成人av| 秋霞影院一区二区| 日韩av一区二区在线影视| 日韩黄色小视频| 秋霞成人午夜伦在线观看| 亚洲福利国产精品| 午夜欧美视频在线观看 | 国产精品亚洲综合一区在线观看| 狠狠色丁香久久婷婷综合_中| 美女脱光内衣内裤视频久久影院| 日本人妖一区二区| 日本欧美在线看| 激情av综合网| 国产成人久久精品77777最新版本| 国产曰批免费观看久久久| 国产精品影视天天线| 粉嫩嫩av羞羞动漫久久久| 国产999精品久久久久久绿帽| 懂色av一区二区三区蜜臀| av一二三不卡影片| 91久久免费观看| 欧美福利电影网| 久久婷婷国产综合国色天香| 久久欧美中文字幕| 国产精品欧美一区二区三区| 亚洲一二三区视频在线观看| 午夜伊人狠狠久久| 精品一区二区三区免费毛片爱| 精品一区二区三区在线播放| 粉嫩绯色av一区二区在线观看| 成av人片一区二区| 精品污污网站免费看| 日韩精品一区二区三区蜜臀 | 麻豆国产精品777777在线| 精品在线视频一区| 成人三级伦理片| 欧美网站一区二区| 欧美成人精品福利| 国产精品久久久久久久裸模| 亚洲国产精品久久久男人的天堂| 久久精品理论片| av电影一区二区| 日韩一区二区在线看片| 国产日韩av一区| 亚洲成av人片一区二区梦乃| 国产最新精品精品你懂的| 99久久er热在这里只有精品66| 欧洲精品视频在线观看| 日韩欧美另类在线| 亚洲欧洲性图库| 久久精品国产免费看久久精品| 成人美女视频在线观看| 7777精品伊人久久久大香线蕉完整版| 久久久久久日产精品| 亚洲一区二区在线播放相泽| 国产一区二区视频在线播放| 色欧美片视频在线观看在线视频| 日韩欧美一区二区在线视频| 亚洲少妇屁股交4| 国产一区二区美女诱惑| 欧美日韩一区二区三区在线看 | 欧美va在线播放| 亚洲一二三四在线观看| 国产成人免费在线观看| 欧美日韩成人综合| 亚洲天堂a在线| 国产乱国产乱300精品| 7777精品久久久大香线蕉| 中文字幕视频一区二区三区久| 久久国产精品无码网站| 欧美日韩在线电影| 亚洲图片激情小说| 成人午夜精品一区二区三区| 精品对白一区国产伦| 五月天国产精品| 欧洲日韩一区二区三区| 亚洲欧洲99久久| 国产成人午夜高潮毛片| xfplay精品久久| 激情国产一区二区| 91精品国产综合久久蜜臀| 亚洲高清视频中文字幕| 69久久99精品久久久久婷婷| 国产精品福利在线播放| 亚洲高清不卡在线| 99国产精品久久久久久久久久| 亚洲欧美精品午睡沙发| 精品国产a毛片| 看片网站欧美日韩| 午夜激情综合网| 欧美成人a在线| 国产在线乱码一区二区三区| 国产精品视频看|