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

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

?? association.cpp

?? 頻繁集挖掘Apriori算法,使用[VC++]實現的
?? CPP
字號:
// CAssociationRule.cpp: implementation of the CAssociationRule class.
//
//////////////////////////////////////////////////////////////////////
#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include "Association.h"

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CAssociationRule::CAssociationRule()
{
    m_minConfidence = 0.90;
    m_numRules = 0;
	
    m_LargeItemSets = (List *)NULL;
	
    m_Rules = (ARRuleSetNode *)NULL;
};

CAssociationRule::~CAssociationRule()
{
    ARRuleSetNode *rn, *temp;

    rn = m_Rules;
    while(rn != (ARRuleSetNode *)NULL)
    {
        temp = rn->next;
        if(rn->m_premise != NULL)
            delete rn->m_premise;

        if(rn->m_consequence != NULL)
            delete rn->m_consequence;

        delete rn;
        rn = temp;
    }

};



void CAssociationRule::genrules()
{
    itemSet *current;
    
    for(int i = 0; i < m_LargeItemSets->size(); i++)
    {
        current = (itemSet *)m_LargeItemSets->get(i);
        if(current->size() > 1)
            ruler(current, current);

//        delete current;
    }
    
    return;
}

void CAssociationRule::ruler(itemSet *Lk, itemSet *Am)
{
    itemSet *current;
    itemSet *Aminusone;
    int pos;
    double conf;
    long necConfidence;


    for(int i = 0; i < Am->size(); i++)
    {
        current = (itemSet *)Am->clone();
        current->remove(i);

        pos = m_LargeItemSets->indexOf(current);
        if(pos >= 0)
        {
            Aminusone = (itemSet *)m_LargeItemSets->get(pos);

            conf = ((double)(Lk->support()))/(double)(Aminusone->support());
            necConfidence = (long)(m_minConfidence*(double)(Aminusone->support()) + 0.5);

            if(necConfidence <= Lk->support())
            {
                add(Lk, Aminusone, conf);

                if(Aminusone->size() > 1)
                    ruler(Lk, Aminusone);
            }

//            delete Aminusone;
        }

        delete current;
    }

    return;
}


void CAssociationRule::add(itemSet *Lk, itemSet *Aminusone, double confidence)
{
    itemSet *rightitems;
    ARRuleSetNode *newRule;
    ARRuleSetNode *browser;

    rightitems = Lk->substract(Aminusone);

    browser = m_Rules;
    while(browser != (ARRuleSetNode *)NULL)
    {
        if((browser->m_premise->compare(Aminusone) == TOTALEQUAL) && (browser->m_consequence->compare(rightitems) == TOTALEQUAL))
        {
            delete rightitems;
            return;
        }

        browser = browser->next;
    }

    newRule = (ARRuleSetNode *) new ARRuleSetNode();

    newRule->m_premise = (itemSet *)Aminusone->clone();
    newRule->m_consequence = (itemSet *)rightitems->clone();

    newRule->m_confidence = confidence;
    newRule->m_support = Lk->support();

    newRule->next = m_Rules;
    m_Rules = newRule;

    m_numRules++;

    return;
}


void CAssociationRule::save(const char *filename)
{
    ARRuleSetNode *currentRule;
    FILE *fp;
	int i;
	itemSet *pitem;

    fp = fopen(filename,"wt");

    /*
	fprintf(fp, "Large Item Sets ...\n\n\n");
	for(i = 0; i < m_LargeItemSets->size(); i++)
	{
		pitem = (itemSet *)m_LargeItemSets->get(i);
		for(int j = 0; j < pitem->size(); j++)
			fprintf(fp, "%d ", pitem->get(j));
		fprintf(fp, "\n");
	}
	fprintf(fp, "\n\n\n");
    */

    currentRule = m_Rules;
    while(currentRule != (ARRuleSetNode *)NULL)
    {
        /*
        fprintf(fp, "%f %f\n", currentRule->m_confidence, currentRule->m_support);
		fprintf(fp, "%d", currentRule->m_premise->size());
        */
                
        for(i = 0; i < currentRule->m_premise->size(); i++)
            fprintf(fp, " %d", currentRule->m_premise->get(i));
        fprintf(fp, "  ---> ");

        /*
		fprintf(fp, "%d", currentRule->m_consequence->size());
        */
                
        for(i = 0; i < currentRule->m_consequence->size(); i++)
            fprintf(fp, " %d", currentRule->m_consequence->get(i));
        fprintf(fp, "\n");
		
        currentRule = currentRule->next;
    }

	fflush(fp);
	fclose(fp);

    return;
}


void CAssociationRule::load(const char *filename)
{
    ARRuleSetNode *currentRule;
	double support, confidence;
	int count, pageno;
    FILE *fp;
	int i;

	printf("Loading Association Rules from %s ... ", filename);
	fflush(stdout);
	
    fp = fopen(filename,"rt");
	while( !feof(fp) )
	{
	    currentRule = (ARRuleSetNode *)new ARRuleSetNode();
		
        fscanf(fp, "%f %f\n", &confidence, &support);
		
        currentRule->m_confidence = confidence;
        currentRule->m_support = support;
		
		fscanf(fp, "%d", &count);
		currentRule->m_premise = (itemSet *)new itemSet();
        for(i = 0; i < count; i++)
		{
            fscanf(fp, " %d", &pageno);
			currentRule->m_premise->add(pageno);
		}
        fscanf(fp, "\n");


		fscanf(fp, "%d", &count);
		currentRule->m_consequence = (itemSet *)new itemSet();
        for(i = 0; i < count; i++)
		{
            fscanf(fp, " %d", &pageno);
			currentRule->m_consequence->add(pageno);
		}
        fscanf(fp, "\n");
		
		currentRule->next = m_Rules;
		m_Rules = currentRule;
    }

	printf(" Finish!");
	fflush(stdout);
	
    return;
}

// Generate recommendations based on observed session
itemSet * CAssociationRule::genRecommendations(itemSet *observed_session, int NumberofTopPages)
{
    ARRuleSetNode *browser;
    TopRule *topRules;
    int i, j, pos, pagenum;
	double pweight;
    itemSet *result;

	pagenum = NumberofTopPages;
	
    topRules = (TopRule *)new TopRule[pagenum];
    for(i = 0; i < pagenum; i++)
    {
        topRules[i].prule = NULL;
        topRules[i].m_similarity = 0.0;
    }

    browser = m_Rules;
    while(browser != (ARRuleSetNode *)NULL)
    {
		pweight = calSimilarity(browser->m_premise, observed_session);
		
		for(pos = 0; pos < pagenum; pos++)
		{
			if(pweight > topRules[pos].m_similarity)
				break;
		}
		if(pos < pagenum)
		{
			for(j = pagenum-2; j >= pos; j--)
			{
				topRules[j+1].prule = topRules[j].prule;
				topRules[j+1].m_similarity = topRules[j].m_similarity;
			}
			topRules[pos].prule = browser;
			topRules[pos].m_similarity = pweight;
		}
		
        browser = browser->next;
    }

	result = (itemSet *)new itemSet();
	result->keeporder(false);
    for(i = 0; i < pagenum; i++)
    {
		if(topRules[i].prule != NULL)
			for(j = 0; j < topRules[i].prule->m_consequence->size(); j++)
				result->add(topRules[i].prule->m_consequence->get(j));
    }

	delete topRules;
	if(result->size() == 0)
	{
		delete result;
		result = (itemSet *)NULL;
	}
	
	return result;	
}


// Calculate the contribution of trace to observed_session
double CAssociationRule::calSimilarity(itemSet *trace, itemSet *observed_session)
{
    int i, observed_page, numIntersection;
	itemSet *itrace, *isession, *iunion;
	double score;
	
	itrace = (itemSet *)new itemSet();
	itrace->keeporder(false);
	for(i = 0; i < trace->size(); i++)
		itrace->add(trace->get(i));
	
	isession = (itemSet *)new itemSet();
	isession->keeporder(false);
	for(i = 0; i < observed_session->size(); i++)
		isession->add(observed_session->get(i));
	
	iunion = (itemSet *)new itemSet();
	iunion->keeporder(false);
	for(i = 0; i < trace->size(); i++)
		iunion->add(trace->get(i));
	for(i = 0; i < observed_session->size(); i++)
		iunion->add(observed_session->get(i));
	
    numIntersection = 0;
	for(i = 0; i < isession->size(); i++)
	{
		observed_page = observed_session->get(i);
		if(itrace->indexOf(observed_page) != -1)
			numIntersection++;
	}

	if(numIntersection == trace->size())
		score = 1.0;
	else
		score = (double)numIntersection / (double)iunion->size();
	
	delete itrace;
	delete isession;
	delete iunion;
	
	return(score);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩在线亚洲一区蜜芽| 在线精品视频小说1| 色综合天天天天做夜夜夜夜做| 丁香天五香天堂综合| 精品国产乱子伦一区| 麻豆成人久久精品二区三区小说| 91精品蜜臀在线一区尤物| 久久国产生活片100| 国产精品伦理一区二区| 一本色道久久加勒比精品| 99久久精品国产麻豆演员表| 亚洲高清免费视频| 欧美成人乱码一区二区三区| www.亚洲国产| 蜜乳av一区二区三区| 婷婷一区二区三区| 中日韩av电影| 中文字幕一区在线观看视频| 精品视频在线看| 欧美人成免费网站| 91首页免费视频| 国产一本一道久久香蕉| 亚洲免费av高清| 2021国产精品久久精品| 日本电影欧美片| 国产精品一区在线观看你懂的| 亚洲国产日日夜夜| 日本欧美一区二区| 亚洲综合色在线| 国产日韩精品一区二区浪潮av | 丝袜美腿亚洲色图| 欧美激情自拍偷拍| 精品国产一区二区三区不卡| 国产精品少妇自拍| 亚洲成人av在线电影| 一区二区三区四区不卡在线 | 99久久精品一区| 91 com成人网| 国产精品二区一区二区aⅴ污介绍| 日韩美女在线视频| 欧美日韩欧美一区二区| 久久久久久久久久久黄色| 欧美一区二区视频在线观看2020 | 美女脱光内衣内裤视频久久网站| 国产麻豆精品久久一二三| 日本福利一区二区| 国产日韩欧美麻豆| 美女网站色91| 欧美性xxxxxxxx| 欧美精品日韩精品| 欧美精品第1页| 亚洲卡通欧美制服中文| 亚洲国产成人av好男人在线观看| 国产精品综合av一区二区国产馆| 欧美日韩一区二区三区免费看| 亚洲精品一区二区精华| 日韩电影在线一区二区三区| 91在线视频18| 国产三区在线成人av| 中文字幕av一区二区三区免费看| 轻轻草成人在线| 狠狠v欧美v日韩v亚洲ⅴ| 国产成人综合视频| 91视频在线观看免费| 国产视频一区二区在线观看| 精品一区二区三区视频| 国产91丝袜在线18| 久久先锋影音av鲁色资源| 人禽交欧美网站| 欧美精品日韩综合在线| 亚洲v精品v日韩v欧美v专区| 色女孩综合影院| 一区二区三区不卡视频| 91丨国产丨九色丨pron| 亚洲欧美怡红院| 成人性生交大合| 欧美欧美午夜aⅴ在线观看| 一区二区三区精密机械公司| 99久久精品国产毛片| 亚洲精品自拍动漫在线| 色悠久久久久综合欧美99| 亚洲人成网站精品片在线观看| 91热门视频在线观看| 亚洲激情欧美激情| 欧美日韩美少妇| 麻豆91在线观看| 国产日韩欧美综合一区| yourporn久久国产精品| 亚洲日本中文字幕区| 狠狠色丁香婷婷综合| 国产免费久久精品| 91天堂素人约啪| 亚洲国产人成综合网站| 欧美成人精品福利| 成人黄色电影在线| 久久九九国产精品| 一本大道av伊人久久综合| 午夜伊人狠狠久久| 久久久久99精品一区| av成人老司机| 日韩中文字幕不卡| 国产亚洲精品中文字幕| 欧洲av在线精品| 美女一区二区在线观看| 国产精品视频九色porn| 9191精品国产综合久久久久久| 韩国精品主播一区二区在线观看 | 一个色在线综合| 欧美一区中文字幕| 成人手机电影网| 丝袜国产日韩另类美女| 久久精品一区四区| 欧美天堂亚洲电影院在线播放| 久久国产尿小便嘘嘘| 综合久久久久综合| 日韩欧美一卡二卡| 在线欧美日韩国产| 懂色av一区二区三区免费观看| 亚洲第四色夜色| 国产精品入口麻豆九色| 日韩三级视频中文字幕| 日本三级亚洲精品| 国产精品久久久久久久久果冻传媒| 欧美日韩国产另类一区| thepron国产精品| 国产专区综合网| 亚洲国产精品一区二区久久| 中文字幕av一区二区三区免费看| 日韩一区二区三区电影| 在线观看一区二区视频| 成人免费视频视频在线观看免费 | 欧美日本免费一区二区三区| 高清视频一区二区| 精品一区二区三区在线播放视频| 亚洲美女偷拍久久| 国产精品视频一二三区| 精品国产麻豆免费人成网站| 在线精品观看国产| 91日韩在线专区| 成人激情黄色小说| 国产99精品视频| 国产乱码精品一区二区三区五月婷| 天使萌一区二区三区免费观看| 亚洲精品少妇30p| 亚洲视频一区二区在线观看| 中文字幕免费观看一区| 久久久久久久网| 国产午夜精品一区二区三区四区| 日韩丝袜美女视频| 日韩免费电影网站| 日韩免费观看2025年上映的电影| 91精品欧美久久久久久动漫| 欧美高清视频一二三区 | 一区二区三区丝袜| 一区精品在线播放| 国产精品嫩草影院com| 国产日韩视频一区二区三区| 国产片一区二区| 国产精品妹子av| 亚洲欧美视频一区| 亚洲午夜久久久久| 日韩精品一区第一页| 全国精品久久少妇| 国产成人8x视频一区二区| 成人不卡免费av| 91色乱码一区二区三区| 欧美日韩在线播放三区四区| 欧美日韩激情在线| 精品成人在线观看| 国产欧美日韩精品在线| 亚洲色欲色欲www| 亚洲国产欧美日韩另类综合| 免费成人小视频| 国产一区二区三区久久悠悠色av| 成人免费看黄yyy456| 在线免费观看日本一区| 日韩一区二区精品在线观看| 久久久久久一二三区| 亚洲三级在线观看| 青青草原综合久久大伊人精品优势| 国产精品456| 在线亚洲欧美专区二区| 精品国产三级电影在线观看| 国产精品久久久久一区二区三区共| 亚洲一二三区不卡| 极品少妇xxxx精品少妇偷拍| 91亚洲资源网| 日韩精品一区在线| 亚洲免费色视频| 国产综合久久久久影院| 欧美综合在线视频| 精品福利二区三区| 亚洲国产一区视频| 国产大陆精品国产| 在线播放中文字幕一区| 国产精品乱码一区二区三区软件| 偷偷要91色婷婷| 91网站在线播放| 亚洲国产精品激情在线观看| 亚洲va欧美va人人爽|