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

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

?? antsystem.h

?? Optimization Algorithms螞蟻算法!~
?? H
字號:
#pragma once

namespace ACO
{
	//#ifndef __ANTSYSTEM_H                                               
	//#define __ANTSYSTEM_H
	using namespace std;
#include <vector>


	extern CAntConstants gAntConstants;


	class CAnt
	{
	public:
		int currentCity;                //current City
		int nextCity;                    //Next City to Visit
		vector<int>visitedCities; //visited Cities
		vector<int>path;            //current Tour
		int pathIndex;               
		double tourLength;		
		CAnt()
		{
			visitedCities.resize(gAntConstants.MAX_CITIES * gAntConstants.MAX_CITIES);
			path.resize(gAntConstants.MAX_CITIES * gAntConstants.MAX_CITIES);
		}

		~CAnt()
		{
			visitedCities.resize(0);
			path.resize(0);
		}
	};

	class CAntSystem
	{
	public:
		const int MAX_CITIES;		//number of cities
		const int MAX_ANTS;       //number of ants		
		int ALPHA;                       //relative importance of pheromone trail
		int BETA;                         //relative importance of distance between cities
		double RHO;                   //evaporation coefficient
		int QVAL;	
		double INIT_PHEROMONE;//initial pheromone concentration
		

		int _curTime;                     //Number of epochs
		double _elapsedTime;      //Elapsed time in actual algorithm
		CAnt* _ants;               //Pointer to Ants
		CPoint*_cities;                 //Poiner to Cities

		double** _distance;         //Holds the distance between cities
		double** _pheromone;    //Array holds the pheromone concentration
		                                         //between cities
		double _bestSoFar;          //best Tour So Far
		double _worstSoFar;        //worst Tour So Far
		double _bestPossible;
		int _bestIndex;
		int _worstIndex;
		bool _ProblemSolved;        //Problem is Solved
		CChart* _graph;                //Pointer to Graph

		//-------------------------------------------------
		//  Constructor
		//-------------------------------------------------            
		CAntSystem(int CityNo,int AntNo,int Alpha=1,int Beta=1,double Rho=0.5):MAX_CITIES(CityNo),MAX_ANTS(AntNo),
			ALPHA(Alpha),BETA(Beta),RHO(Rho)
		{			
			QVAL= 100;		
			INIT_PHEROMONE = 1.0/MAX_CITIES;			
			//MAX_TOUR = MAX_CITIES*MAX_DISTANCE;
			_bestSoFar = CGlobals::INFINITY;
			_worstSoFar=0;
			_bestPossible=CGlobals::INFINITY;
			_bestIndex=0;
			_worstIndex=0;
			_ProblemSolved=false;
			//Ant ini
			_ants = new CAnt[MAX_ANTS];
			_cities = new CPoint[MAX_CITIES];
			_distance = new double*[MAX_CITIES];

			for(int i = 0;i<MAX_CITIES;i++)
			{
				_distance[i]=new double[MAX_CITIES];
			}

			_pheromone = new double*[MAX_CITIES];
			for(int i = 0;i<MAX_CITIES;i++)
			{
				_pheromone[i]=new double[MAX_CITIES];
			}

			_graph=NULL;
			_elapsedTime=0;
		}

		//-------------------------------------------------
		//  
		//-------------------------------------------------
		~CAntSystem()
		{

			delete[] _ants;
			delete[] _cities;

			for(int i = 0;i<MAX_CITIES;i++)
				delete[] _distance[i];
			delete[]  _distance;

			for(int i = 0;i<MAX_CITIES;i++)
				delete[] _pheromone[i];
			delete[]  _pheromone;			

		}

		void AttachGraph(CChart* pGraph)
		{
			this->_graph=pGraph;
		}

		//-------------------------------------------------
		//  
		//-------------------------------------------------
		double DistanceA_to_B(CPoint a,CPoint b)
		{
			double x_distance = a.x - b.x;
			double y_distance = a.y - b.y;
			return sqrt(x_distance*x_distance + y_distance*y_distance);
		}
		//-------------------------------------------------
		// Calculate_bestPossibleRoute 
		//-------------------------------------------------
		void CalculateBestPossibleRoute()
		{
			_bestPossible = 0;
			double x_distance=0;
			double y_distance=0;
			for(int i = 0;i<MAX_CITIES-1;i++)
			{
				_bestPossible+=DistanceA_to_B(_cities[i],_cities[i+1]);
			}

			_bestPossible+=DistanceA_to_B(_cities[MAX_CITIES-1],_cities[0]);
		}

		//-------------------------------------------------
		//  
		//-------------------------------------------------
		void Init( CRect rect )
		{
			int from, to, ant;
			const int margin = 0;
			double radius;
			int offset = 10;
			int width = rect.right - rect.left;
			int height = rect.bottom-rect.top;


			if(width < height)
			{
				radius = width-offset;
			}
			else
			{
				radius=height-offset;
			}
			
			CPoint midPoint;
			midPoint.x = rect.left + width/2+offset;
			midPoint.y = rect.top + height/2 ;
			//midPoint.x = rect.right- radius+offset;
			//midPoint.y = rect.top + height/2 ;
			double SegmentSize= 2*CGlobals::PI/MAX_CITIES;
			double angle=0;

			/* Create the _cities and their locations */
			for (from = 0 ; from < MAX_CITIES ; from++) {

				/* Randomly place _cities around the grid */
				if (gAntConstants.PM == pmRandom)
				{
					//_cities[from].x = RandomInteger( 0,MAX_DISTANCE );
					//_cities[from].y = RandomInteger( 0,MAX_DISTANCE );
				}
				else if(gAntConstants.PM==pmCircular)
				{
					_cities[from].x = (int)(midPoint.x + sin(angle)*radius/2);
					_cities[from].y = (int)(midPoint.y +cos(angle)*radius/2);
					angle+=SegmentSize;
				}

				for (to = 0 ; to < MAX_CITIES ; to++) {
					_distance[from][to] = 0.0;
					_pheromone[from][to] = INIT_PHEROMONE;
				}

			}

			// Compute the _distances for each of the _cities on the map /
			for ( from = 0 ; from < MAX_CITIES ; from++) 
			{
				for ( to = 0 ; to < MAX_CITIES ; to++) 
				{
					if ((to != from) && (_distance[from][to] == 0.0)) 
					{
						int xd = abs(_cities[from].x - _cities[to].x);
						int yd = abs(_cities[from].y - _cities[to].y);

						_distance[from][to] = sqrt( ((double)xd * xd) + (yd * yd) );
						_distance[to][from] = _distance[from][to];
					}
				}
			}

			// Initialize the _ants /
			to = 0;
			for ( ant = 0 ; ant < MAX_ANTS ; ant++ )
			{
				// Distribute the _ants to each of the _cities uniformly 
				if (to == MAX_CITIES)
					to = 0;
				_ants[ant].currentCity = to++;

				for ( from = 0 ; from < MAX_CITIES ; from++ )
				{
					_ants[ant].visitedCities[from] = 0;
					_ants[ant].path[from] = -1;
				}

				_ants[ant].pathIndex = 1;
				_ants[ant].path[0] = _ants[ant].currentCity;
				_ants[ant].nextCity = -1;
				_ants[ant].tourLength = 0.0;

				// Load the ant's current city into VisitedCities List 
				_ants[ant].visitedCities[_ants[ant].currentCity] = 1;

			}
			this->CalculateBestPossibleRoute();
		}
		//-------------------------------------------------
		//  
		//-------------------------------------------------
		void RestartAntSystem( void )
		{
			int ant, i, to=0;

			for ( ant = 0 ; ant < MAX_ANTS ; ant++ ) {

				if (_ants[ant].tourLength < _bestSoFar) {
					_bestSoFar = _ants[ant].tourLength;
					_bestIndex = ant;
				}

				if (_ants[ant].tourLength > _worstSoFar) {
					_worstSoFar = _ants[ant].tourLength;
					_worstIndex = ant;
				}

				if(abs(_bestSoFar - _bestPossible) <0.0005)
					_ProblemSolved=true;

				_ants[ant].nextCity = -1;
				_ants[ant].tourLength = 0.0;

				for (i = 0 ; i < MAX_CITIES ; i++) {
					_ants[ant].visitedCities[i] = 0;
					_ants[ant].path[i] = -1;
				}

				if (to == MAX_CITIES) to = 0;
				_ants[ant].currentCity = to++;

				_ants[ant].pathIndex = 1;
				_ants[ant].path[0] = _ants[ant].currentCity;

				_ants[ant].visitedCities[_ants[ant].currentCity] = 1;

			}

		}


		//-------------------------------------------------------------------
		//AntProduct
		//------------------------------------------------------------------
		double AntProduct( int from, int to )
		{
			return (( pow( _pheromone[from][to], ALPHA ) *pow( (1.0 / _distance[from][to]), BETA ) ));
		}


		//-------------------------------------------------------------------
		// Select Next City
		//------------------------------------------------------------------
		int GetNextCity( int ant )
		{
			int from, to;
			double denom=0.0;

			// Choose the next city to visit 
			from = _ants[ant].currentCity;

			//Work out denominator of formula
			for (to = 0 ; to < MAX_CITIES ; to++) {
				if (_ants[ant].visitedCities[to] == 0) {
					denom += AntProduct( from, to );
				}
			}	

			do {

				double p;

				to++;
				if (to >= MAX_CITIES) to = 0;
				if ( _ants[ant].visitedCities[to] == 0 ) 
				{

					p = AntProduct(from, to)/denom;
					if (RandomFloat() < p ) 
						break;
				}

			} while (1);
			return to;
		}


		//-------------------------------------------------------------------
		//SimulateAnts
		//------------------------------------------------------------------

		int SimulateAnts( void )
		{
			int k;
			int moving = 0;

			for (k = 0 ; k < MAX_ANTS ; k++) {

				/* Ensure this ant still has _cities to visit */
				if (_ants[k].pathIndex < MAX_CITIES) {

					_ants[k].nextCity = GetNextCity( k );
					_ants[k].visitedCities[_ants[k].nextCity] = 1;
					_ants[k].path[_ants[k].pathIndex++] = _ants[k].nextCity;
					_ants[k].tourLength += _distance[_ants[k].currentCity][_ants[k].nextCity];

					/* Handle the final case (last city to first) */
					if (_ants[k].pathIndex == MAX_CITIES) {
						_ants[k].tourLength += 
							_distance[_ants[k].path[MAX_CITIES-1]][_ants[k].path[0]];
					}

					_ants[k].currentCity = _ants[k].nextCity;
					moving++;
				}

			}

			return moving;
		}


		//-------------------------------------------------------------------
		//UpdateTrails
		//------------------------------------------------------------------

		void UpdateTrails( void )
		{
			int from, to, i, ant;

			/* _pheromone Evaporation */
			for (from = 0 ; from < MAX_CITIES ; from++) {

				for (to = 0 ; to < MAX_CITIES ; to++) {

					if (from != to) {

						_pheromone[from][to] *= (1.0 - RHO);

						if (_pheromone[from][to] < 0.0) _pheromone[from][to] = 0;

					}

				}

			}

			// Add new _pheromone to the trails

			// Look at the tours of each ant
			for (ant = 0 ; ant < MAX_ANTS ; ant++) {

				// Update each leg of the tour given the tour length
				for (i = 0 ; i < MAX_CITIES ; i++) {

					if (i < MAX_CITIES-1) {
						from = _ants[ant].path[i];
						to = _ants[ant].path[i+1];
					} else {
						from = _ants[ant].path[i];
						to = _ants[ant].path[0];
					}

					_pheromone[from][to] += (QVAL / _ants[ant].tourLength);
					_pheromone[to][from] = _pheromone[from][to];

				}

			}

			for (from = 0 ; from < MAX_CITIES ; from++)
			{
				for (to = 0 ; to < MAX_CITIES ; to++) 
				{
					_pheromone[from][to] *= RHO;
				}
			}

		}



		//-------------------------------------------------------------------
		//
		//------------------------------------------------------------------
		void DrawCities(CMemDC* pMemDC)
		{
			int citRad=5;
			for(int i = 0;i<MAX_CITIES;i++)
			{
				pMemDC->Ellipse(_cities[i].x - citRad,_cities[i].y - citRad,_cities[i].x + citRad,_cities[i].y +citRad);
			}
		}

		//-------------------------------------------------------------------
		//
		//------------------------------------------------------------------
		void DrawEdges(CMemDC* pMemDC)
		{
			const int colStep = 255;
			double phLow=1110;
			double phHi = 0;
			double phTemp;
			CPen* oldPen;
			CPen pen;

			//iteratate through _pheromone and find highest and lowest
			for(int i = 0;i<MAX_CITIES;i++)
			{
				for(int j=0;j<MAX_CITIES;j++)
				{
					if(i!=j)
					{
						phTemp = _pheromone[i][j];
						if(phTemp>phHi)
						{
							phHi=phTemp;
						}

						if(phTemp<phLow)
						{
							phLow= phTemp;
						}

					}
				}//inner
			}//outer

			double phStep = (phHi )/colStep;

			for(int i = 0;i<MAX_CITIES;i++)
			{
				for(int j=0;j<MAX_CITIES;j++)
				{
					if(i!=j)
					{
						if(_pheromone[i][j]>INIT_PHEROMONE)
						{
							CPoint ctFrom = _cities[i];
							CPoint ctTo = _cities[j];


							double pher = (_pheromone[i][j]/(phHi))*255;

							//Select the pen
							CColor color;
							color.SetRed((int)(255-pher));
							color.SetGreen((int)(255-pher));
							color.SetBlue((int)(255));							
							CPen pen(PS_SOLID,1,color);						
							oldPen=pMemDC->SelectObject(&pen);
							pMemDC->MoveTo(ctFrom.x,ctFrom.y);
							pMemDC->LineTo(ctTo.x,ctTo.y);					
							pMemDC->SelectObject(oldPen);
						}//if pher<INIT__pheromone

					}
				}//inner
			}//outer
			//Now Write Debug Info
			gFont.SetBold(true);
			gFont.SetUnderline(true);
			pMemDC->SelectObject(gFont);
			char buffer[100];
			sprintf(buffer,"Epoch = %d",_curTime);
			pMemDC->TextOut(52,10,buffer,(int)strlen(buffer));
			gFont.SetBold(false);
			gFont.SetUnderline(false);				
			pMemDC->SelectObject(gFont);

			if(_bestSoFar!=CGlobals::INFINITY)
			{
				sprintf(buffer,"Best  SoFar = %.2f",this->_bestSoFar);
				pMemDC->SetTextColor(CColor::blue);
				pMemDC->TextOut(52,30,buffer,(int)strlen(buffer));
				
			


				sprintf(buffer,"Best Possible = %.2f",this->_bestPossible);
				pMemDC->SetTextColor(CColor::green);
				pMemDC->TextOut(52,50,buffer,(int)strlen(buffer));

				sprintf(buffer,"Elapsed Time = %.2f(ms)",this->_elapsedTime);
				pMemDC->SetTextColor(CColor::black);
				pMemDC->TextOut(52,70,buffer,(int)strlen(buffer));

			}			

			if(this->_graph!=NULL )
			{							
				_graph->SetRange(0,_curTime+50,0,_worstSoFar+1);
				_graph->SetXYValue(_curTime,_bestSoFar,_curTime,0);
				_graph->SetXYValue(_curTime,_bestPossible,_curTime,1);				
			}
		}
	};


}//namespace

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本高清无吗v一区| 国产亚洲污的网站| 欧美第一区第二区| 亚洲欧美日韩久久| 精品一区二区三区在线观看国产| 99久久伊人网影院| 精品国精品自拍自在线| 亚洲一区中文在线| 成人性生交大片免费看中文| 日韩一级二级三级| 亚洲高清不卡在线| 99精品久久99久久久久| 久久久九九九九| 青青草成人在线观看| 在线观看日韩一区| 国产精品乱码人人做人人爱| 精彩视频一区二区三区| 91精品国产综合久久香蕉的特点 | 日韩毛片精品高清免费| 韩国欧美国产1区| 日韩欧美高清一区| 图片区小说区国产精品视频| 91黄视频在线观看| 亚洲美女淫视频| 99国产麻豆精品| 国产精品乱码一区二区三区软件| 国产老肥熟一区二区三区| 日韩小视频在线观看专区| 天涯成人国产亚洲精品一区av| 色香蕉久久蜜桃| 亚洲欧美精品午睡沙发| 99精品欧美一区二区三区小说| 国产精品美女久久久久久久久| 国产98色在线|日韩| 欧美激情一区三区| 99久久婷婷国产精品综合| 国产精品久久久久久久久搜平片 | av欧美精品.com| 国产肉丝袜一区二区| 国产福利一区在线| 国产精品毛片久久久久久久| 成人黄色小视频在线观看| 中文字幕不卡三区| 色综合久久天天| 亚洲激情五月婷婷| 欧美三级电影网| 美国一区二区三区在线播放| 日韩欧美中文字幕制服| 国产一区二区三区在线看麻豆| 2020国产精品自拍| 欧美色综合久久| 亚洲一区二区欧美日韩| 欧美挠脚心视频网站| 蜜臀av在线播放一区二区三区| 精品国产亚洲在线| 成人动漫一区二区在线| 亚洲综合成人在线| 欧美第一区第二区| jiyouzz国产精品久久| 亚洲不卡在线观看| 欧美精品一区视频| aa级大片欧美| 日韩精品成人一区二区在线| 26uuu久久综合| 色香色香欲天天天影视综合网| 天涯成人国产亚洲精品一区av| 欧美精品一区二区三区蜜桃视频| 成人午夜碰碰视频| 视频一区二区欧美| 国产欧美一区二区精品久导航 | 国产亚洲精久久久久久| 色综合天天狠狠| 精品一区二区在线免费观看| 亚洲精品菠萝久久久久久久| 精品少妇一区二区三区在线播放| 91影院在线免费观看| 日本不卡一区二区| 亚洲欧洲日韩综合一区二区| 日韩一区二区影院| 色综合视频在线观看| 精品亚洲成a人| 亚洲不卡av一区二区三区| 国产亚洲一区二区三区四区| 欧美日韩黄视频| 成人网在线播放| 久久国产精品无码网站| 亚洲图片自拍偷拍| 国产精品久久久久久久久免费相片| 在线观看91av| 91美女片黄在线观看91美女| 韩国成人精品a∨在线观看| 亚洲综合图片区| 国产精品久久久99| 一区二区三区国产精华| 久久影院午夜论| 欧美久久久久中文字幕| 色婷婷亚洲综合| 99在线精品观看| 国产精品91xxx| 久久66热re国产| 美女一区二区久久| 天天色综合天天| 亚洲高清免费观看| 亚洲综合男人的天堂| 亚洲欧美日韩国产综合在线| 中文字幕亚洲区| 国产精品嫩草影院av蜜臀| 久久综合丝袜日本网| 欧美va亚洲va国产综合| 日韩一区二区三区视频在线 | 国产精品久久免费看| 久久精品亚洲一区二区三区浴池| 日韩精品资源二区在线| 日韩一区二区三区电影| 欧美日韩在线观看一区二区| 一本大道av一区二区在线播放| jiyouzz国产精品久久| av亚洲精华国产精华精华 | 国产精品黄色在线观看| 国产精品三级在线观看| 国产精品毛片久久久久久久| 中文av一区二区| 亚洲欧美在线高清| 亚洲精品成人少妇| 亚洲一区二区三区激情| 午夜av一区二区三区| 日日夜夜免费精品| 日本强好片久久久久久aaa| 另类的小说在线视频另类成人小视频在线 | 六月丁香综合在线视频| 免费不卡在线视频| 国产在线视频精品一区| 成人免费视频一区二区| 99国内精品久久| 在线不卡a资源高清| 日韩欧美一区二区在线视频| 久久丝袜美腿综合| 亚洲色图制服诱惑| 日韩精品一二三四| 国产最新精品免费| 99riav久久精品riav| 欧美亚洲综合一区| 欧美成人国产一区二区| 国产精品久久一级| 国产一区欧美二区| 白白色 亚洲乱淫| 欧美丰满嫩嫩电影| 国产片一区二区三区| 亚洲女同女同女同女同女同69| 偷拍一区二区三区四区| 国产传媒一区在线| 欧美在线小视频| 久久久影视传媒| 亚洲图片欧美一区| 国产一区二区三区视频在线播放| 91啪九色porn原创视频在线观看| 欧美另类变人与禽xxxxx| 国产亚洲精品精华液| 亚洲图片欧美色图| 大陆成人av片| 在线播放亚洲一区| 国产精品女主播在线观看| 亚洲一区二区三区在线看| 韩国v欧美v日本v亚洲v| 欧美影视一区在线| 日本一区二区三区在线观看| 三级在线观看一区二区| 91亚洲国产成人精品一区二三 | 国产乱码一区二区三区| 欧美午夜视频网站| 欧美国产精品中文字幕| 免费在线看成人av| 欧美亚洲国产怡红院影院| 欧美激情综合在线| 久草在线在线精品观看| 精品视频一区三区九区| 亚洲视频1区2区| 风间由美一区二区三区在线观看| 这里只有精品99re| 一区二区三区四区不卡视频 | 久久久99精品久久| 日本vs亚洲vs韩国一区三区| 欧美中文字幕一区二区三区| 国产精品不卡视频| 国产成人精品免费| 久久亚洲二区三区| 精品综合久久久久久8888| 538在线一区二区精品国产| 亚洲欧美日韩在线播放| av成人免费在线| 中文字幕一区视频| 粉嫩一区二区三区在线看| 国产亚洲综合性久久久影院| 久久99国产精品麻豆| 欧美成人官网二区| 精彩视频一区二区| 久久午夜色播影院免费高清| 国产曰批免费观看久久久| 精品国产第一区二区三区观看体验| 青椒成人免费视频|