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

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

?? nn-tsp.cpp

?? 這是一個人工智能方面的算法程序
?? CPP
字號:



 
#include <iostream.h>
#include <time.h>
#include <stdio.h>
#include <iomanip>
#include <fstream.h>
#include <string.h>
#include <stdlib.h>
#include <math.h>
#include <ctype.h>


#define MaxCity_Num  10
double dist[MaxCity_Num][MaxCity_Num] ;      //城市間距離矩陣
double  u[MaxCity_Num][MaxCity_Num];         //神經元輸入
double	v[MaxCity_Num][MaxCity_Num];         //神經元輸出

#define A    1.5
#define D    0.05
#define H    1
#define U0   0.02
#define G(x)  ((1.0 + tanh(x / U0)) / 2.0)       //sigmoid函數
double MinDist = 10000.0;



void InitializeNet(double **u,double **v,int n)     //初始化神經元
{  
	int i,j;
	double m;

	for(i = 0; i < n; i++)
		for(j = 0; j < n; j++)
		{
			m = (rand() / (RAND_MAX + 1.0));
			u[i][j] = 0;
			v[i][j] = m;
		}


}


double Energy(double **v,double **dist,int n,double AA,double DD)    //能量函數
{  
	int i;
	int x;
	int y;
	double e;
	double t;
	double value;
	 
	e = 0;
	for(x = 0; x < n; x++)	
	{
		t = 0;
		for(i = 0; i < n; i++)
		{
			t += v[x][i];
		}
		e += (t - 1) * (t - 1);
	}
	
    for(i = 0; i < n; i++)	
	{
		t = 0;
		for(x = 0 ;x < n; x++)
		{
			t += v[x][i];
		}
		e += (t - 1) * (t - 1);
	}	

	t = 0;
	for(x = 0; x < n ; x++)	
	{
        for(y = 0; y < n; y++)
		{
			if(x == y) 
			{
				continue;
			}

            for(i = 0; i < n; i++)
			{
		    	if(i < n - 1)
				{
					t += v[x][i] * dist[x][y] * v[x][i] * v[y][i + 1];
				}
                if(i == n - 1)
				{
					t += v[x][i] * dist[x][y] * v[x][i] * v[y][0];
				}

            }
        }
    }
	
	value = (AA * e + DD * t) / 2;
	return value;


 
}
void Work(double **u,double **v,double **dist,int n,double AA,double DD,double HH)
{
    int i,j,x,y;
	double s,t,z;
    
	for(x = 0; x < n; x++)
	{
        for(i = 0; i < n; i++)
		{
			s = 0;	
			for (j = 0; j < n; j++) 
			{
				s += v[x][j];
			}
		    s -= 1;
			
			t = 0;
            for(y = 0; y < n; y++) 
			{
				t += v[y][i];
            }
			t -= 1;

			s *= AA;
			t *= AA;
		    
			z = 0;
			for(y = 0; y < n; y++) 
			{
				if(i < n-1) 
				{
					z += v[y][i + 1] * dist[x][y];
				}
				if(i == n-1)
				{
					z += v[y][0] * dist[x][y];
				}
			}
			z *= DD;
		    z = -s - t - z;	            
			u[x][i] += HH * z;
			v[x][i] = G(u[x][i]);
		}
	}


}



double distance(double **graph,int road[],int n)        //計算城市間距離
{
    int i;
	double sum;
	
	sum = 0.0;
	for(i = 0; i < n - 1; i++)
	{
		sum += graph[road[i] - 1][road[i + 1] - 1];
	}
    sum += graph[road[i] - 1][road[0] - 1];
	return sum;

}


bool Stop(double **v,int n)            //檢查約束   
{
    int i,j;
    double k;

    for(i = 0; i < n; i++)
		for(j = 0; j < n; j++)
		{
			if((v[i][j] > 0.01) && (v[i][j] < 0.99))
				return 0;
		}

	for(i = 0; i < n; i++)
	{
		k = 0;
        for(j = 0; j < n; j++)
		{
			if(i == j) 
			{
				continue;
			}
			k += v[i][j];
		}
        if((k - 1.0) > 0.01 || (1.0 - k) > 0.01)
		{
			return 0;
		}
	}
    for(i = 0; i < n; i++)
	{
		k = 0;
        for(j = 0; j < n; j++)
		{
			if (i == j) 
			{
				continue;
			}
			k += v[j][i];
		}
        if((k - 1.0) > 0.01 || (1.0 - k) > 0.01)
		{
            return 0;
		}
	}

	return 1;

 
}


double show(double **v,double **dist,int n,int flag)       //顯示輸出結果
{
     int i,j;
     double d;
	 int road[MaxCity_Num];

     if(Stop(v,n))
	 {
		d = 0;
		for(i = 0; i < n; i++)
			for(j = 0; j < n; j++)
			{
				if(v[i][j] > 0.99)
					road[j] = i + 1;
			}
		d = distance(dist,road,n);
		if (MinDist > d)  
		{
			MinDist = d;
		}
	
        if(flag==1)
		{
  
	        cout<<"當前回路為:  ";
	        for(i = 0; i < n; i++)
			{
		        cout<<road[i]<<" ";
			}
            cout<<road[0]<<endl;

            cout<<"路徑長度為:"<<d<<endl<<endl;
 
		}
	 }
	 return d;


}



void RunNet(double **u,double **v,double **dist,int n,double AA,double DD,double HH,int flag)
{
    int count;
    double e,f;

	srand((int)time(0));
	 	
 	for(int i = 1; i <= 100; i++)
	{   
		 count = 0;
                
		 InitializeNet(u,v,n);

 		 f = 0;
		 do
		 { 
			 e = Energy(v,dist,n,AA,DD);
			 Work(u,v,dist,n,AA,DD,HH);
			 count++;
			 
			 if(fabs(e - f) < 1e-20) 
			 {
				 break;
			 }
			 
			 if(Stop(v,n))
			 {
				 break;
			 }
			 
             f = e;
		 }while(count < 1000);  
		 
		// if(flag)
		// {
			 show(v,dist,n,flag);
		 //}
	 }
	
	 

     cout<<"最短路徑長度為:"<<MinDist<<endl;
  
}



void main()
{  
	int City_Num;
    ifstream datafile;                      
    char fileName[10];
	double *uu[MaxCity_Num];
	double *vv[MaxCity_Num];
	double *dd[MaxCity_Num];
	int ShowDist;
	int ShowCurrentResult;

	 
	cout<<"請輸入城市的數目(10):";
	cin>>fileName;
    City_Num=atoi(fileName);

	cout<<"是否查看距離矩陣(1-是,0-否):";
	cin>>ShowDist;

	cout<<"是否查看中間結果(1-是,0-否):";
	cin>>ShowCurrentResult;
	
	for(int k=0;k<MaxCity_Num;k++)                           //初始化鄰接矩陣
         for(int m=0;m<MaxCity_Num;m++)
             dist[k][m]=0;
    datafile.open(strcat(fileName,".txt"));                  //打開文件   

    for(int i=0;i<MaxCity_Num;i++)                           //輸入數據到矩陣
	{	     for(int j=0;j<MaxCity_Num;j++)
		{	datafile>>dist[i][j];
			//dist[j][i]=dist[i][j];
		}
	}

if(ShowDist==1)	
{   
	for( k=0;k<MaxCity_Num;k++)
	  for(int l=0;l<MaxCity_Num;l++)
	     cout<<"dist["<<k<<"]["<<l<<"]="<<dist[k][l]<<" ";
	
	 cout<<endl<<endl;
}

   
	for(i = 0; i <MaxCity_Num; i++) 
	{
		uu[i] = u[i];
		vv[i] = v[i];
		dd[i] = dist[i];
	}

	RunNet(uu,vv,dd,MaxCity_Num,A,D,H,ShowCurrentResult);
 





}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩电影一区| 国产视频亚洲色图| 亚洲日穴在线视频| 99精品国产视频| 亚洲日本成人在线观看| 国产精品二三区| 欧美精品成人一区二区三区四区| 丝袜美腿亚洲综合| 国产亚洲欧美激情| 中文字幕av一区二区三区高| 欧美伊人久久久久久久久影院| 日韩**一区毛片| 国产精品无圣光一区二区| 欧美精品高清视频| 精品国产免费人成电影在线观看四季| 国产成人av一区二区三区在线| 亚洲高清免费视频| 国产精品色哟哟网站| 亚洲免费av网站| 久久久午夜电影| 日韩欧美国产综合| 欧美亚洲动漫另类| 欧美v日韩v国产v| 欧美精品电影在线播放| 亚洲精品一区在线观看| 国产精品电影一区二区| 亚洲国产精品久久人人爱| 麻豆中文一区二区| 亚洲卡通动漫在线| 中文子幕无线码一区tr| 一级日本不卡的影视| 亚洲欧美日韩在线| 精品一区二区三区视频在线观看| 洋洋av久久久久久久一区| 喷白浆一区二区| 奇米精品一区二区三区在线观看 | 国产一区在线不卡| 亚洲福利一区二区| 天天影视涩香欲综合网| 7777精品伊人久久久大香线蕉 | 久久久久久日产精品| 自拍偷拍国产亚洲| 精品一区二区影视| 色天使色偷偷av一区二区| 国产a视频精品免费观看| 国产在线精品一区二区夜色| 午夜久久久久久久久| 国产精品99久久久久久似苏梦涵| 国内精品在线播放| 777午夜精品免费视频| 国产精品每日更新| 精品影院一区二区久久久| 欧美性xxxxxx少妇| 国产精品私人影院| 国产麻豆精品久久一二三| 在线综合视频播放| 亚洲一区二区三区在线看| 亚洲精品一卡二卡| 国产精品一区三区| 精品国产精品网麻豆系列| 日韩制服丝袜先锋影音| 欧美午夜免费电影| 亚洲精品中文在线影院| 色综合久久精品| 成人免费小视频| 三级成人在线视频| 欧美无砖专区一中文字| 亚洲综合精品自拍| 欧美三级中文字幕| 久久精品综合网| 麻豆91精品视频| 精品国产一区二区三区av性色| 日韩二区在线观看| 91麻豆精品国产91久久久久| 午夜视频一区二区三区| 欧美日韩一区 二区 三区 久久精品 | 成人激情黄色小说| 在线看日本不卡| 精品美女被调教视频大全网站| 首页国产欧美久久| 日韩免费电影一区| 国产一区二区三区在线看麻豆| 26uuu久久天堂性欧美| 亚洲精品国产一区二区三区四区在线 | 日韩一级高清毛片| 国产精品成人在线观看| 成人av免费网站| 亚洲美女视频在线观看| 91官网在线观看| 国产人成亚洲第一网站在线播放| 一区二区三区免费网站| 91久久精品午夜一区二区| 午夜视频在线观看一区| 精品福利视频一区二区三区| 国产精品88888| 自拍偷拍亚洲欧美日韩| 欧美日韩精品一区二区三区| 免费久久精品视频| 成人欧美一区二区三区黑人麻豆| 色综合网站在线| 国产亚洲va综合人人澡精品 | 一本大道综合伊人精品热热 | 欧美一区二区成人6969| 一区二区三区在线播放| 欧美一区三区四区| 国产成人综合在线| 日韩成人一区二区三区在线观看| 亚洲精品一区二区三区福利| 一本久道中文字幕精品亚洲嫩| 日韩国产欧美视频| 国产精品国产三级国产aⅴ入口| 欧美日韩在线观看一区二区| 国产麻豆9l精品三级站| 亚洲精品免费在线| 国产视频一区二区三区在线观看| 欧美日韩亚洲综合| 成人免费视频国产在线观看| 中文字幕精品一区| 日韩三级视频中文字幕| 91蜜桃婷婷狠狠久久综合9色| 国产精品久久久久久久久搜平片| 欧美美女一区二区| 99久久精品国产导航| 国内外精品视频| 婷婷一区二区三区| 亚洲视频一区在线| 久久精品视频一区二区| 91精品国产91久久综合桃花| 99re这里只有精品首页| 国产成人精品影视| 精品一区二区三区av| 日韩精品一卡二卡三卡四卡无卡| 亚洲色图制服诱惑| 国产精品福利一区| 久久久国产一区二区三区四区小说 | 五月天亚洲婷婷| 亚洲精品伦理在线| 中文字幕一区二| 国产欧美日韩激情| 久久久久久久久久美女| 欧美v日韩v国产v| 日韩免费在线观看| 欧美一区二区三区影视| 欧美乱妇23p| 欧美精品自拍偷拍动漫精品| 91黄色免费看| 欧美性猛交xxxxxx富婆| 在线视频观看一区| 色94色欧美sute亚洲13| 欧美午夜一区二区三区| 在线观看亚洲a| 欧美三级韩国三级日本三斤 | 老汉av免费一区二区三区| 久久先锋影音av鲁色资源网| 欧美一级欧美三级在线观看| 欧美精品丝袜中出| 69成人精品免费视频| 欧美一区二区三区视频在线观看| 在线91免费看| 欧美va亚洲va在线观看蝴蝶网| 欧美成人a∨高清免费观看| xfplay精品久久| 亚洲国产精品二十页| 亚洲人成伊人成综合网小说| 亚洲国产成人av| 美女视频黄免费的久久 | 色婷婷香蕉在线一区二区| 99久久er热在这里只有精品15| k8久久久一区二区三区| 男人的j进女人的j一区| 狠狠色伊人亚洲综合成人| 国产a区久久久| 欧美探花视频资源| 日韩精品中文字幕在线不卡尤物| 精品国产精品一区二区夜夜嗨| 国产欧美一区二区三区鸳鸯浴 | 中文字幕亚洲一区二区av在线| 中文字幕五月欧美| 五月婷婷久久综合| 岛国精品一区二区| 欧美色中文字幕| 久久综合成人精品亚洲另类欧美| 中文字幕乱码日本亚洲一区二区| 一区二区高清免费观看影视大全| 另类小说图片综合网| av动漫一区二区| 日韩一区二区三区四区| 中文字幕在线不卡| 日韩1区2区3区| 99精品在线免费| 日韩视频一区在线观看| 亚洲视频免费看| 国产精品综合二区| 欧美久久一区二区| 亚洲天堂2014| 国产乱对白刺激视频不卡| 欧美在线播放高清精品| 日本一二三四高清不卡| 蜜臀久久久久久久| 在线视频亚洲一区|