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

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

?? epdlg.cpp

?? 小生境遺傳優化源程序 具有非線性優化問題的解釋
?? CPP
字號:
// EPDlg.cpp : implementation file
//

#include "stdafx.h"
#include "EP.h"
#include "EPDlg.h"
#include "math.h"
#include "time.h"

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

double pi = 3.1415926535897;
/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CEPDlg dialog

CEPDlg::CEPDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CEPDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CEPDlg)
		// NOTE: the ClassWizard will add member initialization here
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CEPDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CEPDlg)
		// NOTE: the ClassWizard will add DDX and DDV calls here
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CEPDlg, CDialog)
	//{{AFX_MSG_MAP(CEPDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_EPSelect, OnEPSelect)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CEPDlg message handlers

BOOL CEPDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CEPDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CEPDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CEPDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CEPDlg::CreatRand(LONG num, double *tempRand)
{
	int i = 0;
	if(bTime)
	{
		srand( (unsigned)time( NULL ) );//設置偽隨機數發生器的種子
		bTime = false;
	}
	for( i = 0; i < num; i++)
		*(tempRand + i) = (double)rand();
}

void CEPDlg::InitializeGen()
{
	N = maxpop;
	maxgen =  100000;
	lemata = 0.8;
	L = 0.001;
	T0 = 0.3;
	bTime = true;

	int i,j;
	double *tempP = new double[N*30];
	CreatRand(N*30,tempP);

	for(i = 0; i < N; i++)//個體數
	{
		//生成初始個體
		for(j = 0; j < 30; j++)//
			oldpop[i].x[j] = int(fmod(*(tempP + i*30 + j),200.0)/200.0 + 0.5);//[0,1]

		//計算各個體的適應值
		oldpop[i].fitness = CalculateFitness(oldpop[i].x);
		newpop[i] = oldpop[i];
	}

	delete tempP;
}

double CEPDlg::CalculateFitness(int* x)
{
	double result = 0;
	int i,j,s = 0;
	for(i = 0; i < 5; i++)
	{
		s = 0;
		for(j = 0; j < 6; j++)
		{
			s += *(x + 6*i + j);
		}
		result += CalculateU(s);
	}

	return(result);
}

//變異產生新的N個個體
void CEPDlg::Mutation( )
{
	int i,j;
	double pk;
	double *tempP = new double[N];
	double x;

	for(i = 0; i < N; i++)//個體數
	{
		CreatRand(N,tempP);
		for(j = 0; j < 30; j++)//
		{
			pk = -pi/2.0 + fmod(*(tempP + j),pi*50.0)/50.0;//[-pi/2.0, pi/2.0]
			x = oldpop[i].x[j] + 1.0*T0*lemata*tan(pk);//pow(lemata,gen - 1)*tan(pk);
//			x = oldpop[i].x[j] + 1.0*T0*pow(lemata,gen - 1)*tan(pk);
			//首先確定x,y是否在定義域,如不在,則需用鏡像原則將其修正
			while(x < 0 || x > 1){
				if(x < 0) x = fmod(fabs(x),1);
				else x = 1 - fmod(x,1);
			}
			newpop[N + i].x[j] = int(x + 0.5);
		}
		newpop[N + i].fitness = CalculateFitness(newpop[N + i].x);
	}

	delete tempP;
}

//用距離函數使個體分配區間
void CEPDlg::Assign()
{
	int i,j,k;
	double dis;
	for(i = 0; i < 2*N -1; i++)//個體數
	for(j = i + 1; j < 2*N; j++)//個體數
	{
		dis = 0;
		for(k = 0; k < 30; k++)//
		{
			dis += pow((int(0.5 + newpop[i].x[k]) - int(0.5 + newpop[j].x[k])),2.0);
		}
		dis = sqrt(dis);
			if(dis < L)//相似
			{
				if(newpop[i].fitness > newpop[j].fitness)	newpop[i].fitness = 0.0;
				else	newpop[j].fitness = 0.0;
			}
	}

}

//選擇
void CEPDlg::Select()
{
	individual tempInd;
	int i,j;
	//按適應值優劣降序排列
	for(j = 0; j < 2*N; j++)
		for(i = j + 1; i < 2*N; i++)
		{
			if(newpop[j].fitness <= newpop[i].fitness)//本例是求最大值
			{
				tempInd = newpop[j];
				newpop[j] = newpop[i];
				newpop[i] = tempInd;
			}
		}
	//篩掉適應值最差的后N個個體后放入oldpop中
	for(i = 0; i < N; i++)
	{
		oldpop[i] = newpop[i] ;
	}
}

void CEPDlg::OnEPSelect() 
{
	int i,kk= 1001;
	int success=0;
//	for(kk = 1001; kk <= 1001; kk++)
//	{
		char  buffer[8];
		FILE *EPFile;
		sprintf(buffer, "%d.txt", kk);
		CString tempFileName = "Result_30var";
		tempFileName = tempFileName + buffer;
		EPFile = fopen(tempFileName, "w" );
		fclose(EPFile);

		InitializeGen();
		gen = 1;
		do{
			Mutation();
			Assign();
			Select();
			gen += 1;
			if(success >= 8) T0 = 0.25;
			if(success >= 18) T0 = 0.2;
			if(success > 23) T0 = 0.1;

			if(oldpop[success].fitness > 4.7){
				//記錄最后結果
				EPFile = fopen(tempFileName, "a+" );
				fprintf(EPFile, "N=%d\tmaxgen=%d\tlemata=%3.6f\tL=%3.6f\tT0=%3.6f\n",N,gen,lemata,L,T0);
				fprintf(EPFile, "%d\t%d\n",success,gen);
				success = success + 1;
				fclose(EPFile);
			}

		}while(newpop[31].fitness < 4.7);//gen < maxgen || 

		EPFile = fopen(tempFileName, "a+" );
		for(i = 0; i < N; i++)
		{
			if(oldpop[i].fitness > 4.7)
			{
			for(int j = 0; j < 30; j++)
				fprintf(EPFile, "%d  ",int(0.5 + oldpop[i].x[j]));
			fprintf(EPFile, "%3.6f\n",oldpop[i].fitness);
			}
		}
		fclose(EPFile);
//	}
}

double CEPDlg::CalculateU(int s)
{
	double us;
	switch (s)
	{
	case 3:
		us = 0.640576;
		break;
	case 2:
	case 4:
			  us = 0.360384;
		break;
	case 1:
	case 5:
			  us = 0;
		break;
	case 0:
	case 6:
			  us = 1;
		break;
	}
		return(us);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品毛片高清在线完整版| 91精品国产91久久综合桃花| 一本大道久久a久久综合| 欧美撒尿777hd撒尿| 奇米精品一区二区三区在线观看| 久久福利资源站| 日韩一卡二卡三卡四卡| 久久久久久久电影| 日韩精品久久久久久| 欧美日韩在线综合| 亚洲免费资源在线播放| 成人av网站在线观看免费| 欧美一区二区三区在线视频| 欧美图片一区二区三区| 男男视频亚洲欧美| 7777精品伊人久久久大香线蕉的 | 日本一二三不卡| 亚洲欧美二区三区| 不卡av在线免费观看| 久久午夜免费电影| 久久国产综合精品| 日韩一区二区三区在线观看| 性做久久久久久| 欧美亚洲国产一区二区三区| 中文字幕字幕中文在线中不卡视频| 国产另类ts人妖一区二区| 日韩欧美中文字幕制服| 日韩高清一区二区| 91精品国产91久久久久久最新毛片| 亚洲综合视频网| 在线中文字幕不卡| 亚洲成人一区二区| 欧美日韩国产高清一区| 日韩精品电影在线观看| 91精品麻豆日日躁夜夜躁| 亚洲成人免费影院| 日韩西西人体444www| 精品影视av免费| 国产午夜亚洲精品不卡| 成人av网站在线观看免费| 亚洲视频综合在线| 欧美调教femdomvk| 蜜臂av日日欢夜夜爽一区| 精品福利在线导航| 成人av资源下载| 亚洲综合一区在线| 91麻豆精品国产无毒不卡在线观看| 奇米777欧美一区二区| 久久亚洲精品国产精品紫薇| 成人永久免费视频| 一区二区三区四区在线播放| 91麻豆精品国产| 国产成人在线色| 亚洲人成伊人成综合网小说| 欧美日本在线观看| 国内精品视频一区二区三区八戒| 国产精品欧美综合在线| 在线观看国产一区二区| 免播放器亚洲一区| 国产精品色在线观看| 欧美三级三级三级爽爽爽| 韩国av一区二区三区在线观看| 国产精品萝li| 欧美一级高清片| www.成人在线| 日本亚洲天堂网| 欧美国产在线观看| 正在播放亚洲一区| 国产精品一区二区不卡| 一区二区国产盗摄色噜噜| 精品久久久久99| 色婷婷香蕉在线一区二区| 老司机精品视频在线| 亚洲精品免费在线播放| 久久―日本道色综合久久| 在线视频观看一区| 国产精品一区二区三区网站| 亚洲国产日韩av| 国产目拍亚洲精品99久久精品| 欧美日韩另类一区| 波多野结衣精品在线| 免播放器亚洲一区| 洋洋成人永久网站入口| 国产精品久久久久久久久免费丝袜| 在线成人av影院| 91日韩一区二区三区| 国产99久久久国产精品| 蜜臀av一区二区三区| 亚洲精品菠萝久久久久久久| 久久伊人中文字幕| 这里是久久伊人| 在线视频你懂得一区二区三区| 国产激情91久久精品导航| 日韩精品一二三| 亚洲午夜电影在线观看| 亚洲婷婷在线视频| 国产精品久久毛片av大全日韩| 久久先锋影音av鲁色资源网| 欧美一区二区网站| 欧美日韩国产在线观看| 在线亚洲一区二区| 91蝌蚪porny成人天涯| 成人国产精品视频| 成人免费黄色大片| 成人国产电影网| 成人app软件下载大全免费| 国产成人午夜精品5599| 狠狠色狠狠色综合日日91app| 日本不卡免费在线视频| 日日摸夜夜添夜夜添国产精品| 亚洲主播在线观看| 亚洲成人免费在线| 日韩黄色免费网站| 琪琪一区二区三区| 国模冰冰炮一区二区| 国产美女一区二区| 国产精品 欧美精品| 成人一级视频在线观看| 91在线视频在线| 在线视频亚洲一区| 欧美乱熟臀69xxxxxx| 69成人精品免费视频| 欧美一区二区免费视频| 337p日本欧洲亚洲大胆精品| ww亚洲ww在线观看国产| 国产欧美综合色| 自拍偷拍欧美激情| 一区二区三区免费观看| 丝袜亚洲另类欧美| 捆绑变态av一区二区三区| 国产精品综合一区二区三区| 丁香婷婷综合色啪| 91官网在线观看| 在线不卡a资源高清| 精品国免费一区二区三区| 久久久噜噜噜久久人人看 | 26uuu精品一区二区| 国产欧美一区二区精品性色| 亚洲视频免费在线| 亚洲成a人片综合在线| 老司机一区二区| 波多野结衣在线一区| 欧美日韩一区在线| 26uuu精品一区二区三区四区在线| 中文字幕不卡一区| 天天综合色天天| 豆国产96在线|亚洲| 在线观看网站黄不卡| 日韩欧美国产综合| 国产精品久久久久久久久久免费看| 亚洲综合在线电影| 国产一区二区三区| 日本韩国欧美在线| 国产日产精品一区| 一区二区三区影院| 国产美女精品一区二区三区| 95精品视频在线| 亚洲精品一区二区三区福利| 亚洲品质自拍视频| 韩国一区二区视频| 欧美亚洲一区三区| 国产亚洲综合在线| 人人爽香蕉精品| 色婷婷综合久久| 国产亚洲精品超碰| 奇米色一区二区三区四区| 91视频91自| 国产亚洲va综合人人澡精品| 日本三级韩国三级欧美三级| 99久久婷婷国产| 久久影院午夜论| 免费人成黄页网站在线一区二区| 92精品国产成人观看免费 | 亚洲在线免费播放| av综合在线播放| 久久久精品国产免费观看同学| 日韩二区三区四区| 色8久久精品久久久久久蜜| 国产精品乱人伦一区二区| 国产一区激情在线| 日韩女同互慰一区二区| 亚洲成av人综合在线观看| 99精品久久免费看蜜臀剧情介绍| 久久天堂av综合合色蜜桃网| 奇米影视7777精品一区二区| 色嗨嗨av一区二区三区| 国产精品美女久久久久久久久久久| 免费av成人在线| 67194成人在线观看| 五月婷婷另类国产| 欧美色老头old∨ideo| 亚洲精选一二三| 色婷婷精品久久二区二区蜜臀av| 《视频一区视频二区| av电影在线不卡| 亚洲柠檬福利资源导航| 99麻豆久久久国产精品免费 | 91影院在线观看| 国产精品国产馆在线真实露脸 | 欧美主播一区二区三区|