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

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

?? arminerdlg.cpp

?? 頻繁集挖掘Apriori算法,使用[VC++]實現的
?? CPP
字號:
// ARMinerDlg.cpp : implementation file
//

#include "stdafx.h"
#include "math.h"
#include "ARMiner.h"
#include "ARMinerDlg.h"

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

/////////////////////////////////////////////////////////////////////////////
// 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()

/////////////////////////////////////////////////////////////////////////////
// CARMinerDlg dialog

CARMinerDlg::CARMinerDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CARMinerDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CARMinerDlg)
	m_data = _T("data.txt");
	m_rule = _T("Result.txt");
	m_support = 0.2;
	m_confidence = 0.5;
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CARMinerDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CARMinerDlg)
	DDX_Control(pDX, IDC_EDIT_DATA, m_dataEdit);
	DDX_Text(pDX, IDC_EDIT_DATA, m_data);
	DDX_Text(pDX, IDC_EDIT_RULE, m_rule);
	DDX_Text(pDX, IDC_EDIT_SUPPORT, m_support);
	DDX_Text(pDX, IDC_EDIT_CONFIDENCE, m_confidence);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CARMinerDlg, CDialog)
	//{{AFX_MSG_MAP(CARMinerDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON_MINING, OnButtonMining)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CARMinerDlg message handlers

BOOL CARMinerDlg::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 CARMinerDlg::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 CARMinerDlg::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 CARMinerDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}


#include "Apriori.h"
#include "Association.h"
#include "itemSet.h"
List * CARMinerDlg::loadItemSets(const char *datafile, int& max_pageno, bool keeporder)
{
    List *m_data;
    itemSet *pitemset;
    char line[20*4096];
    int pageno;
    char *t, *s;
    FILE *fp;

    // try to open the data file
    if((fp = fopen(datafile, "rt")) == NULL)
		return (List *)NULL;

    // this is the data structure that stores the input data
    m_data = (List *)new List();
    max_pageno = -1;

    // Read in each line, extract all the items within this line
    while(fgets(line, 20*4096, fp) != NULL)
    {
        if (strchr(line, ',') != NULL)
        {
            s = (char *) new char[strlen(line) + 1];
            strcpy(s, line);
            if ((t = strtok(s, ",")) == NULL)
            {
                delete s;
                break;
            }

            pitemset = (itemSet *)new itemSet();
			pitemset->keeporder(keeporder);
            pageno = atoi(t);
            if(max_pageno < pageno)
                max_pageno = pageno;
            pitemset->add(pageno);
            
            t = strtok((char *)NULL, ",");

            for ( ; t != NULL; t = strtok((char *)NULL, ","))
            {
                pageno = atoi(t);
                if(max_pageno < pageno)
                    max_pageno = pageno;
				
                pitemset->add(pageno);
            }

            // if the length of the session is greater than 1, then insert it into the session list
            if(pitemset->size() > 1)
            {
                pitemset->support(1);
                m_data->add(pitemset);
            }
			else
	            delete pitemset;

            delete s;
        }
    }

    fclose(fp);

    return(m_data);
}



void CARMinerDlg::OnButtonMining() 
{
	// TODO: Add your control notification handler code here
	UpdateData();
	//m_data;存放數據項集的文件名
	//m_rule;存放挖掘出的關聯規則的文件名
	//m_support;最小支持度
	//m_confidence;最小信任度

	CString s,t;
	float tickCount=GetTickCount();

	CApriori *m_apriori;
	CAssociationRule *m_rules;//關聯規則對象
    List *traindata;//訓練數據鏈
    int pagenum;//屬性個數
    double support = 0.2, confidence = 0.5;
	double m_ItemSupport;
    support=m_support;confidence=m_confidence;
	
    // Read in the structure of the web site from a map file
    if((traindata = loadItemSets(m_data, pagenum, false)) == NULL)
	{
		//從數據集文件m_data裝裁項集到traindata鏈
		MessageBox("Cannot load data!");
		return;
	}
	
    m_apriori = new CApriori();
    m_apriori->setsupport(support);
	m_apriori->pagenum = pagenum + 1;

    // Finding large Itemsets from training data
	//以下函數從traindata中找出頻繁集保存在m_apriori的m_Ls成員中,
	//訓練集中項集總個數保存在m_sampleNum成員中
    m_apriori->FindLargeItemSets(traindata);
    
    // Association Rules from extracted large item sets
    m_rules = new CAssociationRule();
    m_rules->setconfidence(confidence);
    m_rules->m_LargeItemSets = m_apriori->m_Ls;//把頻繁集保存到規則對象m_rules中
	
	//以下把頻繁集保存到文件中
    FILE *fp;
	itemSet *current;
    fp=fopen(m_rule,"w");
	s.Format("頻繁項集如下(最小支持度:%f,信任度:%f)\n\n",m_support,m_confidence);
	fprintf(fp,s);
    for(int i = 0; i < m_rules->m_LargeItemSets->size(); i++)
    {
		
        current = (itemSet *)m_rules->m_LargeItemSets->get(i);
        if(current->size() >1)
		{
			s="";
			for(int j=0;j<current->size();j++)
			{
				t.Format("%d,",current->get(j));
				s+=t;
			}
			m_ItemSupport=(double)current->support()/(double)m_apriori->m_sampleNum;
			s.Delete(strlen(s)-1,1);
			s.Format("%s   支持度為%d/%d=%.3f",s,current->support(),m_apriori->m_sampleNum,m_ItemSupport);
			fprintf(fp,s);
			fprintf(fp,"\n");
			
		}
	}
	fflush(fp);
	fclose(fp);
			
//    m_rules->genrules();//由頻繁集生成關聯規則
//    m_rules->save(m_rule);//保存關聯規則

    // Clear off
    delete m_apriori;
    delete m_rules;
    delete traindata;

    fp=fopen(m_rule,"a+");
	//取結束時間,保存執行時間
	tickCount=GetTickCount()-tickCount;
	s.Format("\n挖掘時間 %.3f秒",tickCount/1000);
	fprintf(fp,s);
	fflush(fp);
	fclose(fp);

	MessageBox("挖掘完成!");
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91浏览器打开| 91国偷自产一区二区三区观看| 国产91丝袜在线观看| 不卡一二三区首页| 99精品欧美一区二区三区综合在线| 欧美亚洲高清一区| 亚洲欧洲在线观看av| 成人动漫视频在线| 丁香天五香天堂综合| 3atv一区二区三区| 国产精品欧美久久久久一区二区| 免费日本视频一区| 99热在这里有精品免费| 欧美本精品男人aⅴ天堂| 一区二区不卡在线播放| 成人av网站免费| 久久综合99re88久久爱| 免费人成在线不卡| 欧美精三区欧美精三区| 一区二区三区在线不卡| 成人高清视频在线| 欧美激情在线一区二区三区| 美女视频黄频大全不卡视频在线播放| 91香蕉视频mp4| 国产午夜一区二区三区| 久久精品国产精品青草| 91麻豆精品国产无毒不卡在线观看 | 成人激情小说网站| 91精品麻豆日日躁夜夜躁| 伊人夜夜躁av伊人久久| 波多野结衣中文字幕一区 | 精品久久久久一区二区国产| 亚洲国产裸拍裸体视频在线观看乱了| av午夜一区麻豆| 日本一区免费视频| 处破女av一区二区| 国产欧美日韩亚州综合| 国产乱码精品一区二区三区av| 精品国内二区三区| 极品美女销魂一区二区三区免费| 欧美人动与zoxxxx乱| 亚洲国产日日夜夜| 欧美电影在线免费观看| 美女一区二区视频| www精品美女久久久tv| 国产一本一道久久香蕉| 石原莉奈一区二区三区在线观看| 一区二区欧美国产| 精品污污网站免费看| 亚洲高清免费视频| 5月丁香婷婷综合| 激情都市一区二区| 国产人成一区二区三区影院| 国产jizzjizz一区二区| 亚洲蜜臀av乱码久久精品蜜桃| 91福利在线免费观看| 天天免费综合色| 精品美女在线播放| 大桥未久av一区二区三区中文| 日韩一区在线看| 欧美日韩高清一区二区| 久久精品免费看| 国产精品女同互慰在线看| 日本韩国视频一区二区| 日本不卡123| 国产蜜臀97一区二区三区| 欧美亚洲高清一区| 国产欧美综合在线| 久久久亚洲午夜电影| 97se狠狠狠综合亚洲狠狠| 亚洲大尺度视频在线观看| 欧美成人在线直播| www.在线欧美| 肉丝袜脚交视频一区二区| 精品国产一区a| 色先锋aa成人| 加勒比av一区二区| 亚洲精品免费一二三区| 精品成人a区在线观看| 色偷偷久久一区二区三区| 久久精品国产99久久6| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 亚洲成人av电影在线| 日本一区二区三区国色天香| 欧美无人高清视频在线观看| 国产不卡视频在线观看| 三级影片在线观看欧美日韩一区二区| 国产精品嫩草影院com| 91精品国产综合久久久蜜臀粉嫩| 成人av网址在线观看| 久久97超碰国产精品超碰| 亚洲综合色婷婷| 国产精品理伦片| 精品国产乱码久久久久久免费| 欧美网站大全在线观看| 91热门视频在线观看| 国产成人av网站| 美女一区二区视频| 日韩国产欧美一区二区三区| 亚洲免费在线播放| 国产精品美女久久久久aⅴ| 久久久久久久电影| 精品国产sm最大网站免费看| 在线成人av影院| 欧美日韩另类一区| 91久久精品网| 91成人免费在线视频| 成人丝袜视频网| 国产乱一区二区| 国产一区二区看久久| 精品中文字幕一区二区小辣椒 | 欧美亚洲丝袜传媒另类| 色婷婷综合视频在线观看| 91在线观看下载| 99视频一区二区三区| 成人精品国产福利| jizzjizzjizz欧美| 波多野结衣亚洲一区| 成人av在线播放网址| 波多野结衣在线一区| 99久久精品免费看国产免费软件| 国产福利91精品一区二区三区| 精品综合免费视频观看| 国产在线精品不卡| 国产suv精品一区二区6| 成人黄色国产精品网站大全在线免费观看 | 精品久久一二三区| 这里只有精品电影| 久久久三级国产网站| 成人欧美一区二区三区小说| 亚洲一区二区欧美激情| 美女视频免费一区| 在线免费观看一区| 欧美一区二区播放| 亚洲三级电影全部在线观看高清| 久久午夜色播影院免费高清| www国产精品av| 亚洲成av人片在www色猫咪| 亚洲超碰97人人做人人爱| 污片在线观看一区二区| 丝袜美腿亚洲综合| 久久福利视频一区二区| 亚洲免费资源在线播放| 国精产品一区一区三区mba桃花| 韩国视频一区二区| 91在线码无精品| 欧美日韩精品三区| 精品女同一区二区| 国产精品国产精品国产专区不片| 亚洲精品自拍动漫在线| 日日噜噜夜夜狠狠视频欧美人| 韩国女主播一区| 91免费版在线| 欧美一区二区成人6969| 欧美极品美女视频| 午夜视频一区在线观看| 国产成人综合精品三级| 色播五月激情综合网| 精品人在线二区三区| 亚洲欧美日韩系列| 久久精品国产网站| 91麻豆123| 国产午夜精品久久久久久免费视| 亚洲精品综合在线| 国产露脸91国语对白| 欧美三级在线看| 国产精品视频在线看| 天堂影院一区二区| 97se亚洲国产综合在线| 精品日韩一区二区| 亚洲一区二区精品视频| 国产高清无密码一区二区三区| 欧美亚洲一区二区在线| 国产欧美日韩亚州综合| 强制捆绑调教一区二区| 色狠狠色噜噜噜综合网| 欧美国产禁国产网站cc| 青青草国产精品97视觉盛宴| 在线观看不卡视频| 国产精品毛片高清在线完整版| 免费av成人在线| 欧美日韩精品一区二区三区四区| 国产欧美va欧美不卡在线| 免费成人在线观看视频| 制服丝袜日韩国产| 亚洲一区二区三区在线播放| 成人av在线电影| 欧美激情一区二区三区四区| 久久精品国产精品亚洲综合| 欧美一级二级在线观看| 亚洲在线视频免费观看| 99久久精品国产精品久久| 久久精品水蜜桃av综合天堂| 久久精品免费观看| 日韩一卡二卡三卡国产欧美| 视频一区欧美精品| 在线电影国产精品| 日韩二区三区四区| 777久久久精品| 美女脱光内衣内裤视频久久影院|