⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 遗传算法view.cpp

📁 关于遗传算法的一个源代码
💻 CPP
📖 第 1 页 / 共 2 页
字号:
// 遗传算法View.cpp : implementation of the CMyView class
//

#include "stdafx.h"
#include "遗传算法.h"

#include "Dialog0.h"
#include "Dialog2.h"
#include "遗传算法Set.h"
#include "遗传算法Doc.h"
#include "遗传算法View.h"

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

/////////////////////////////////////////////////////////////////////////////
// CMyView

IMPLEMENT_DYNCREATE(CMyView, CRecordView)

BEGIN_MESSAGE_MAP(CMyView, CRecordView)
	//{{AFX_MSG_MAP(CMyView)
	ON_BN_CLICKED(IDC_CODE, OnCode)
	ON_BN_CLICKED(IDC_CODEE, OnCodee)
	ON_BN_CLICKED(IDC_FITCOMPUTE, OnFitcompute)
	ON_BN_CLICKED(IDC_SELECT, OnSelect)
	ON_BN_CLICKED(IDC_MUTATION, OnMutation)
	ON_BN_CLICKED(IDC_XUNHUAN, OnXunhuan)
	ON_BN_CLICKED(IDC_NEW, OnNew)
	ON_BN_CLICKED(IDC_XUNHUAN2, OnXunhuan2)
	//}}AFX_MSG_MAP
	// Standard printing commands
	ON_COMMAND(ID_FILE_PRINT, CRecordView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, CRecordView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, CRecordView::OnFilePrintPreview)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CMyView construction/destruction

CMyView::CMyView()
	: CRecordView(CMyView::IDD)
{
	//{{AFX_DATA_INIT(CMyView)
	m_pSet = NULL;
	m_fit1 = 0.0f;
	m_fit2 = 0.0f;
	m_fit3 = 0.0f;
	m_fit4 = 0.0f;
	m_Fmin = 0;
	m_Smin = 0;
	m_11 = _T("");
	m_12 = _T("");
	m_13 = _T("");
	m_14 = _T("");
	m_15 = _T("");
	m_21 = _T("");
	m_22 = _T("");
	m_23 = _T("");
	m_24 = _T("");
	m_25 = _T("");
	m_31 = _T("");
	m_32 = _T("");
	m_33 = _T("");
	m_34 = _T("");
	m_35 = _T("");
	m_41 = _T("");
	m_42 = _T("");
	m_43 = _T("");
	m_44 = _T("");
	m_45 = _T("");
	m_mute = 0;
	m_crossport = 0;
	m_muteport = 0;
	//}}AFX_DATA_INIT
	// TODO: add construction code here

}

CMyView::~CMyView()
{
}

void CMyView::DoDataExchange(CDataExchange* pDX)
{
	CRecordView::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CMyView)
	DDX_Text(pDX, IDC_EDIT1, m_fit1);
	DDX_Text(pDX, IDC_EDIT2, m_fit2);
	DDX_Text(pDX, IDC_EDIT3, m_fit3);
	DDX_Text(pDX, IDC_EDIT4, m_fit4);
	DDX_Text(pDX, IDC_EDIT5, m_Fmin);
	DDX_Text(pDX, IDC_EDIT6, m_Smin);
	DDX_Text(pDX, IDC_EDIT7, m_11);
	DDX_Text(pDX, IDC_EDIT9, m_12);
	DDX_Text(pDX, IDC_EDIT10, m_13);
	DDX_Text(pDX, IDC_EDIT11, m_14);
	DDX_Text(pDX, IDC_EDIT12, m_15);
	DDX_Text(pDX, IDC_EDIT13, m_21);
	DDX_Text(pDX, IDC_EDIT14, m_22);
	DDX_Text(pDX, IDC_EDIT15, m_23);
	DDX_Text(pDX, IDC_EDIT16, m_24);
	DDX_Text(pDX, IDC_EDIT17, m_25);
	DDX_Text(pDX, IDC_EDIT18, m_31);
	DDX_Text(pDX, IDC_EDIT19, m_32);
	DDX_Text(pDX, IDC_EDIT20, m_33);
	DDX_Text(pDX, IDC_EDIT21, m_34);
	DDX_Text(pDX, IDC_EDIT22, m_35);
	DDX_Text(pDX, IDC_EDIT23, m_41);
	DDX_Text(pDX, IDC_EDIT24, m_42);
	DDX_Text(pDX, IDC_EDIT25, m_43);
	DDX_Text(pDX, IDC_EDIT26, m_44);
	DDX_Text(pDX, IDC_EDIT27, m_45);
	DDX_Text(pDX, IDC_EDIT28, m_mute);
	DDX_Text(pDX, IDC_EDIT29, m_crossport);
	DDX_Text(pDX, IDC_EDIT30, m_muteport);
	//}}AFX_DATA_MAP
}

BOOL CMyView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return CRecordView::PreCreateWindow(cs);
}

void CMyView::OnInitialUpdate()
{
	m_pSet = &GetDocument()->m_mySet;
	CRecordView::OnInitialUpdate();
	GetParentFrame()->RecalcLayout();
	ResizeParentToFit();

}

/////////////////////////////////////////////////////////////////////////////
// CMyView printing

BOOL CMyView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// default preparation
	return DoPreparePrinting(pInfo);
}

void CMyView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add extra initialization before printing
}

void CMyView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add cleanup after printing
}

/////////////////////////////////////////////////////////////////////////////
// CMyView diagnostics

#ifdef _DEBUG
void CMyView::AssertValid() const
{
	CRecordView::AssertValid();
}

void CMyView::Dump(CDumpContext& dc) const
{
	CRecordView::Dump(dc);
}

CMyDoc* CMyView::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CMyDoc)));
	return (CMyDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CMyView database support
CRecordset* CMyView::OnGetRecordset()
{
	return m_pSet;
}


/////////////////////////////////////////////////////////////////////////////
// CMyView message handlers


/*****************初始种群编码*******************/
void CMyView::OnCode() 
{
    CMyDoc* pDoc1=GetDocument();
	m_pSet->MoveFirst();
	m_Shi=0;
	while(m_Shi<4)
	{
		m_Shi++;
		//////////////////////////////////
		if(m_pSet->m_column2 == "50-60w")
		{
			pDoc1->Oldpop[m_Shi].chrom[0]=1;
			pDoc1->Oldpop[m_Shi].chrom[1]=1;
		}
		else if(m_pSet->m_column2 == "40-50w")
		{
			pDoc1->Oldpop[m_Shi].chrom[0]=1;
			pDoc1->Oldpop[m_Shi].chrom[1]=0;
		}
		else if(m_pSet->m_column2 == "30-40w")
		{
			pDoc1->Oldpop[m_Shi].chrom[0]=0;
			pDoc1->Oldpop[m_Shi].chrom[1]=1;
		}
		else if(m_pSet->m_column2 == "20-30w")
		{
			pDoc1->Oldpop[m_Shi].chrom[0]=0;
			pDoc1->Oldpop[m_Shi].chrom[1]=0;
		}
		else 
		{
			pDoc1->Oldpop[m_Shi].chrom[0]=2;
			pDoc1->Oldpop[m_Shi].chrom[1]=2;
		}

		//////////////////////////////
        if(m_pSet->m_column3=="no")
			pDoc1->Oldpop[m_Shi].chrom[2]=0;
		else if(m_pSet->m_column3=="yes")
            pDoc1->Oldpop[m_Shi].chrom[2]=1;
        ////////////////////////////////
		if(m_pSet->m_column4=="no")
			pDoc1->Oldpop[m_Shi].chrom[3]=0;
		else if(m_pSet->m_column4=="yes")
            pDoc1->Oldpop[m_Shi].chrom[3]=1;
         ////////////////////////////////
        if(m_pSet->m_column5=="woman")
			pDoc1->Oldpop[m_Shi].chrom[4]=0;
		else if(m_pSet->m_column5=="man")
            pDoc1->Oldpop[m_Shi].chrom[4]=1;
         ///////////////////////////////
		if(m_pSet->m_column6 == "50-59")
		{
			pDoc1->Oldpop[m_Shi].chrom[5]=1;
			pDoc1->Oldpop[m_Shi].chrom[6]=1;
		}
		else if(m_pSet->m_column6 == "40-49")
		{
			pDoc1->Oldpop[m_Shi].chrom[5]=1;
			pDoc1->Oldpop[m_Shi].chrom[6]=0;
		}
		else if(m_pSet->m_column6 == "30-39")
		{
			pDoc1->Oldpop[m_Shi].chrom[5]=0;
			pDoc1->Oldpop[m_Shi].chrom[6]=1;
		}
		else if(m_pSet->m_column6 == "20-29")
		{
			pDoc1->Oldpop[m_Shi].chrom[5]=0;
			pDoc1->Oldpop[m_Shi].chrom[6]=0;
		}
		else 
		{
			pDoc1->Oldpop[m_Shi].chrom[5]=2;
			pDoc1->Oldpop[m_Shi].chrom[6]=2;
		}
        //////////////////////////////////
		m_pSet->MoveNext();

	}
	int i,j;
	for(i=1;i<=4;i++)
		for(j=0;j<=6;j++)
			pDoc1->Newpop[i].chrom[j]=pDoc1->Oldpop[i].chrom[j];

	DeCode();//在屏幕上显示处世个种群元素

	
}

/*****************训练数据编码*******************/

void CMyView::OnCodee() 
{
	CMyDoc* pDoc1=GetDocument();
	int i=0;
	m_pSet->MoveFirst();
	while(i<4)
	{
		i++;
		m_pSet->MoveNext();
	}
	m_Can=0;
    while(m_Can<6)
	{
		m_Can++;
		//////////////////////////////////
		if(m_pSet->m_column2 == "50-60w")
		{
			pDoc1->Cankao[m_Can].chrom[0]=1;
			pDoc1->Cankao[m_Can].chrom[1]=1;
		}
		else if(m_pSet->m_column2 == "40-50w")
		{
			pDoc1->Cankao[m_Can].chrom[0]=1;
			pDoc1->Cankao[m_Can].chrom[1]=0;
		}
		else if(m_pSet->m_column2 == "30-40w")
		{
			pDoc1->Cankao[m_Can].chrom[0]=0;
			pDoc1->Cankao[m_Can].chrom[1]=1;
		}
		else if(m_pSet->m_column2 == "20-30w")
		{
			pDoc1->Cankao[m_Can].chrom[0]=0;
			pDoc1->Cankao[m_Can].chrom[1]=0;
		}
		else 
		{
			pDoc1->Cankao[m_Can].chrom[0]=2;
			pDoc1->Cankao[m_Can].chrom[1]=2;
		}

		//////////////////////////////
        if(m_pSet->m_column3 == "no")
			pDoc1->Cankao[m_Can].chrom[2]=0;
		else if(m_pSet->m_column3 == "yes")
            pDoc1->Cankao[m_Can].chrom[2]=1;
        ////////////////////////////////
		if(m_pSet->m_column4 == "no")
			pDoc1->Cankao[m_Can].chrom[3]=0;
		else if(m_pSet->m_column4 == "yes")
            pDoc1->Cankao[m_Can].chrom[3]=1;
         ////////////////////////////////
        if(m_pSet->m_column5 == "woman")
			pDoc1->Cankao[m_Can].chrom[4]=0;
		else if(m_pSet->m_column5 == "man")
            pDoc1->Cankao[m_Can].chrom[4]=1;
         ///////////////////////////////
		if(m_pSet->m_column6 == "50-59")
		{
			pDoc1->Cankao[m_Can].chrom[5]=1;
			pDoc1->Cankao[m_Can].chrom[6]=1;
		}
		else if(m_pSet->m_column6 == "40-49")
		{
			pDoc1->Cankao[m_Can].chrom[5]=1;
			pDoc1->Cankao[m_Can].chrom[6]=0;
		}
		else if(m_pSet->m_column6 == "30-39")
		{
			pDoc1->Cankao[m_Can].chrom[5]=0;
			pDoc1->Cankao[m_Can].chrom[6]=1;
		}
		else if(m_pSet->m_column6 == "20-29")
		{
			pDoc1->Cankao[m_Can].chrom[5]=0;
			pDoc1->Cankao[m_Can].chrom[6]=0;
		}
		else 
		{
			pDoc1->Cankao[m_Can].chrom[5]=2;
		    pDoc1->Cankao[m_Can].chrom[6]=2;
		}
        //////////////////////////////////
		m_pSet->MoveNext();

	}
	
}


/**********************计算种群中各元素的适应度***********************/

void CMyView::OnFitcompute() 
{
	CMyDoc* pDoc1=GetDocument();
	int M=0,N=0;
	int i=0,j=0,k=0;
	for(i=1;i<=4;i++)
	{
		M=0,N=0;
	
		for(j=1;j<=6;j++)
		{
			
			if(pDoc1->Newpop[i].chrom[2] == pDoc1->Cankao[j].chrom[2])
			{
			    if((pDoc1->Newpop[i].chrom[0] == pDoc1->Cankao[j].chrom[0])&&(pDoc1->Newpop[i].chrom[1] == pDoc1->Cankao[j].chrom[1]))
					N++;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -