📄 遗传算法view.cpp
字号:
// 遗传算法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 + -