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

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

?? psovrptw.cpp

?? 一個求解車輛路徑問題的粒子群算法的源碼
?? CPP
字號:
// PsoVrptw.cpp: implementation of the CPsoVrptw class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "VRP.h"
#include "math.h"
#include "PsoVrptw.h"

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CPsoVrptw::CPsoVrptw()
{

}

CPsoVrptw::~CPsoVrptw()
{

}

void CPsoVrptw::reserial(CPsoVrptw::Node *PNode)
{
	int i,j,count;
	double data;

	for(i=1;i<=TASKTW;i++)
	{
		data=PNode->Xr[i];
		count=1;
		for(j=1;j<=TASKTW;j++)
		{
			if(PNode->Xv[i]==PNode->Xv[j]&&data-PNode->Xr[j]>=0.000001)
				count++;
			if(PNode->Xv[i]==PNode->Xv[j]&&(fabs(data-PNode->Xr[j])<0.000001)&&i>j)
				count++;
		}
		PNode->iXr[i]=count;
	}
    
	return;
}

double CPsoVrptw::Eval(CPsoVrptw::PNODE *PNode)
{
	int i,j,k,step;
	double dist[VECHI+1];
	double weight[VECHI+1];
	double All_weight,All_dist;
    int pre;
	double pe=50,pl=50,speed=50;
	double time[VECHI+1];



label1:
	reserial(PNode);

	for(i=1;i<=VECHI;i++)
	{
		dist[i]=0;
		time[i]=0;
	    weight[i]=0;
	}

	for(i=1;i<=VECHI;i++)
	{
		step=1;
		pre=0;
		do
		{
		  for(j=1;j<=TASKTW;j++)
			if(PNode->Xv[j]==i&&PNode->iXr[j]==step)
				break;
		  if(j<=TASKTW)
			//找到車輛i的step次任務點j
		  {
		    dist[i]+=dist_M[pre][j];
		    weight[i]+=GPNode.weight[j];
			time[i]+=dist_M[pre][j]/speed;
			if(time[i]>GPNode.end_time[j])
			{
				dist[i]+=pl*(time[i]-GPNode.end_time[j]);
				time[i]+=GPNode.time[j];
			}else
			if(time[i]<GPNode.start_time[j])
			{
				dist[i]+=pe*(GPNode.start_time[j]-time[i]);
				time[i]=GPNode.start_time[j]+GPNode.time[j];
			}else
				time[i]+=GPNode.time[j];
			pre=j;
		  }
		  step=step+1;
		}while(j<=TASKTW);
        dist[i]+=dist_M[pre][0];
	}
	 All_weight=0;
	 for(i=1;i<=VECHI;i++)
		 All_weight+=weight[i];
	 All_dist=0;
	 for(i=1;i<=VECHI;i++)
		 All_dist+=dist[i];
   PNode->value=All_dist;
   for(i=1;i<=VECHI;i++)
	   if(weight[i]>8.0)
	   {
		   do{
			   j=rand()%VECHI+1;
		   }while(j==i);
		   do{
			   k=rand()%TASKTW+1;
		   }while(PNode->Xv[k]!=i);
		   //從車輛中找出一輛取代i
		   PNode->Xv[k]=j;
		   goto label1;
	   }

   return PNode->value;
}

void CPsoVrptw::initialize()
{
  int i,j;
  /*VNode[0].Node.Xv[1]=2;
  VNode[0].Node.Xv[2]=2;
  VNode[0].Node.Xv[3]=2;
  VNode[0].Node.Xv[4]=1;
  VNode[0].Node.Xv[5]=3;
  VNode[0].Node.Xv[6]=1;
  VNode[0].Node.Xv[7]=3;
  VNode[0].Node.Xv[8]=3;
  //
  VNode[0].Node.iXr[1]=2;
  VNode[0].Node.iXr[2]=3;
  VNode[0].Node.iXr[3]=1;
  VNode[0].Node.iXr[4]=2;
  VNode[0].Node.iXr[5]=2;
  VNode[0].Node.iXr[6]=1;
  VNode[0].Node.iXr[7]=3;
  VNode[0].Node.iXr[8]=1;

  Eval(&VNode[0].Node);*/


  for(i=0;i<PopSize;i++)
	{
		for(j=1;j<=TASKTW;j++)
		{
			VNode[i].Node.Xv[j]=rand()%VECHI+1;
			VNode[i].Node.Xr[j]=rand()%TASKTW+1;
            VNode[i].Node.Vv[j]=(rand()%10>5)?rand()%VECHI:(-(rand()%VECHI));
            VNode[i].Node.Vr[j]=(rand()%10>5)?rand()%TASKTW:(-(rand()%TASKTW));
		}
        Eval(&VNode[i].Node);
  }
  for(i=0;i<PopSize;i++)
  {
	  VNode[i].LocalNode=VNode[i].Node;
  }
  //生成局部最小
  j=0;
  double minvalue=MAX;
  for(i=0;i<PopSize;i++)
  {
	  if(VNode[i].Node.value<minvalue)
	  {
		  minvalue=VNode[i].Node.value;
		  j=i;
	  }
  }
  GBest=VNode[j].Node;
  //全局最小值 
}

void CPsoVrptw::localbest(int Pos)
{
	if(VNode[Pos].Node.value<VNode[Pos].LocalNode.value)
		VNode[Pos].LocalNode=VNode[Pos].Node;
}

void CPsoVrptw::globalbest(int Pos)
{
	if(VNode[Pos].Node.value<GBest.value)
		GBest=VNode[Pos].Node;
}

void CPsoVrptw::comput_Pso(int Pos)
{
	int i;
	double c1=0.729,r1=1.49445,r2=1.49445;
	double s;
	CPsoVrptw::PNODE PNode;
	double rand1,rand2;
	rand1=double(rand()%100)/100;
	rand2=double(rand()%100)/100;

	PNode=VNode[Pos].Node;
	for(i=1;i<=TASKTW;i++)
	{
		PNode.Vv[i]=(int)(c1*PNode.Vv[i]+r1*rand1*(VNode[Pos].LocalNode.Xv[i]-PNode.Xv[i])+r2*rand2*(GBest.Xv[i]-PNode.Xv[i]));
		if(PNode.Vv[i]>MaxVSpeed)
		  PNode.Vv[i]=MaxVSpeed;
        if(PNode.Vv[i]<-MaxVSpeed)
		  PNode.Vv[i]=-MaxVSpeed;
		
		PNode.Vr[i]=c1*PNode.Vr[i]+r1*rand1*(VNode[Pos].LocalNode.Xr[i]-PNode.Xr[i])+r2*rand2*(GBest.Xr[i]-PNode.Xr[i]);
		if(PNode.Vr[i]>MaxRTWSpeed)
		  PNode.Vr[i]=MaxRTWSpeed;
        if(PNode.Vr[i]<-MaxRTWSpeed)
		  PNode.Vr[i]=-MaxRTWSpeed;
	}
    
	for(i=1;i<=TASKTW;i++)
	{
        s=PNode.Xv[i]+PNode.Vv[i];
		PNode.Xv[i]=s>(int)s?(int)s+1:(int)s;

      	if(PNode.Xv[i]>VECHI)
		  PNode.Xv[i]=VECHI;
		if(PNode.Xv[i]<1)
		  PNode.Xv[i]=1;
        PNode.Xr[i]=PNode.Xr[i]+PNode.Vr[i];
	}
	Eval(&PNode);
	if(PNode.value>VNode[Pos].Node.value)
		VNode[Pos].Node=PNode;

}

double CPsoVrptw::Vrp_Pso(int *Try_step)
{
	int Step,i;
	double prebest;

	initialize();
	prebest=GBest.value;
for(Step=0;Step<200;Step++)
	{
		for(i=0;i<PopSize;i++)
		{
			comput_Pso(i);
			localbest(i);
			globalbest(i);
		}
		if(fabs(prebest-GBest.value)<0.000001) {Step++;prebest=GBest.value;}
		else
		{Step=0;prebest=GBest.value;}
	}//while(Step<20);
		
    *Try_step=Step;
	return GBest.value;

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲午夜久久久久久久久电影网 | 欧美写真视频网站| 成人性生交大片免费看中文网站| 日韩av中文字幕一区二区 | 欧美色欧美亚洲另类二区| 成人h动漫精品一区二区| 成人av在线播放网站| 成人午夜在线视频| 91视频免费看| 精品视频在线免费观看| 欧美日韩免费观看一区三区| 欧美视频一区二区三区四区| 欧美高清视频www夜色资源网| 欧美日韩久久一区| 欧美r级在线观看| 久久这里只有精品首页| 国产午夜精品理论片a级大结局| 国产欧美一区二区三区在线看蜜臀| 欧美国产日韩亚洲一区| 亚洲视频你懂的| 亚洲1区2区3区4区| 韩国视频一区二区| 成人黄色一级视频| 欧美系列在线观看| 精品国产乱码久久久久久闺蜜| xnxx国产精品| 亚洲精品一二三| 久热成人在线视频| 成人动漫在线一区| 欧美一区二区高清| 最新国产成人在线观看| 五月天久久比比资源色| 国产乱妇无码大片在线观看| 色悠久久久久综合欧美99| 日韩精品一区二区三区三区免费 | 色综合中文字幕国产 | 9人人澡人人爽人人精品| 欧美午夜一区二区三区免费大片| 日韩欧美中文字幕公布| 亚洲三级电影全部在线观看高清| 奇米亚洲午夜久久精品| 99国产一区二区三精品乱码| 欧美一区二区三区人| 国产精品国产三级国产专播品爱网| 亚洲高清视频中文字幕| 成人一道本在线| 日韩精品中文字幕一区二区三区| 国产精品初高中害羞小美女文| 青青草原综合久久大伊人精品优势| 成人高清免费观看| 久久综合久久综合久久| 天堂蜜桃91精品| 91丨porny丨中文| 欧美激情一区二区三区全黄| 开心九九激情九九欧美日韩精美视频电影 | 亚洲精品国产a| 国产传媒一区在线| 日韩丝袜美女视频| 午夜精品一区在线观看| 91网站黄www| 中文字幕一区二区三区在线播放| 九九在线精品视频| 欧美一级在线观看| 日韩电影免费在线| 欧美久久久影院| 亚洲一区二区精品3399| 日本韩国欧美三级| 亚洲乱码国产乱码精品精98午夜| 国产精品亚洲人在线观看| 欧美一区二区三区日韩| 日本欧美一区二区三区乱码| 欧美在线一区二区| 亚洲一区在线观看免费| 日本道免费精品一区二区三区| 亚洲人成网站精品片在线观看| 国产福利精品一区二区| 国产欧美在线观看一区| 国产福利一区二区三区视频在线 | 91一区二区在线| 中文字幕亚洲视频| av一本久道久久综合久久鬼色| 中文字幕视频一区| 一本一道久久a久久精品| 一区二区不卡在线播放| 欧美日韩国产在线播放网站| 日韩中文欧美在线| 日韩精品在线一区| 国产麻豆视频一区| 国产精品伦理在线| 在线精品视频一区二区| 亚洲国产综合91精品麻豆| 91麻豆精品91久久久久久清纯| 日本不卡不码高清免费观看| 久久综合九色综合欧美亚洲| 国产福利精品导航| 亚洲欧美日韩一区二区 | 久久精品男人的天堂| 国产成a人亚洲精| 亚洲日穴在线视频| 欧美一卡二卡在线| 成人免费看视频| 亚洲一区二区三区四区在线| 日韩欧美高清一区| 成人av资源在线| 亚洲不卡av一区二区三区| 亚洲精品在线观| 91视频免费观看| 韩国欧美一区二区| 亚洲图片欧美一区| 久久精品欧美日韩精品| 欧美三级电影在线看| 国产精品一二三| 日韩精品亚洲一区二区三区免费| 国产亚洲人成网站| 欧美精品在线一区二区| 国产91精品欧美| 日韩成人一级大片| 自拍偷在线精品自拍偷无码专区| 欧美精品在线观看一区二区| 成人高清av在线| 久久精品久久精品| 一区二区三区欧美日韩| 久久综合色鬼综合色| 欧美丰满美乳xxx高潮www| 成人福利视频网站| 黑人巨大精品欧美黑白配亚洲| 亚洲成a人片在线不卡一二三区 | 亚洲一区二区三区自拍| 久久久精品天堂| 欧美一区二区三区白人 | 日日夜夜一区二区| 亚洲免费高清视频在线| 中文乱码免费一区二区| 欧美成人性战久久| 欧美日韩一区二区三区高清| 99久久99久久免费精品蜜臀| 国产精品99久久久久久似苏梦涵| 婷婷开心激情综合| 性做久久久久久免费观看| 亚洲精品免费一二三区| 中文字幕一区二区三| 国产拍揄自揄精品视频麻豆| 26uuu亚洲综合色欧美| 日韩亚洲欧美在线| 国产乱一区二区| 欧美aaaaa成人免费观看视频| 国产亚洲一本大道中文在线| 国产91精品欧美| 国产一区二区三区日韩| 美国三级日本三级久久99| 日韩一区精品视频| 日本视频中文字幕一区二区三区 | 91视频一区二区| 色综合天天性综合| 91天堂素人约啪| 91亚洲资源网| 欧美少妇一区二区| 欧美三级一区二区| 欧美精品123区| 日韩免费一区二区三区在线播放| 日韩欧美国产综合在线一区二区三区 | 国产成人在线网站| 国产成人av电影在线| 成人免费视频一区二区| 97国产一区二区| 欧美午夜片在线看| 亚洲人成7777| 无吗不卡中文字幕| 免费在线一区观看| 欧美视频在线一区| 欧美吞精做爰啪啪高潮| 欧美天堂亚洲电影院在线播放| 午夜精品久久久久久久久久久| 亚洲成av人片| 久久99精品视频| 国产suv精品一区二区6| 91在线一区二区三区| 欧美精品免费视频| 久久这里只精品最新地址| 国产精品入口麻豆九色| 亚洲亚洲精品在线观看| 狠狠色综合播放一区二区| 成人18视频日本| 欧美精品第1页| 久久久久国色av免费看影院| 一区二区三区四区激情| 久久国产三级精品| 99国产精品一区| 欧美电影免费观看高清完整版在 | 一区二区三区日韩精品| 午夜欧美一区二区三区在线播放| 老色鬼精品视频在线观看播放| 丰满亚洲少妇av| 欧美丰满一区二区免费视频| 日本一区二区久久| 肉色丝袜一区二区| 99r精品视频| 久久综合色鬼综合色| 亚洲va欧美va天堂v国产综合| 国产aⅴ综合色|