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

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

?? associationrule.cpp

?? apriori算法源碼
?? CPP
字號:
// CAssociationRule.cpp: implementation of the CAssociationRule class.
//
//////////////////////////////////////////////////////////////////////
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include "AssociationRule.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一区二区三区免费野_久草精品视频
国产精品国产精品国产专区不蜜| 91免费小视频| 99综合电影在线视频| 欧美日韩aaa| 国产亚洲精久久久久久| 午夜精品福利一区二区三区av| 福利一区二区在线| 日韩欧美久久一区| 亚洲精品伦理在线| 国产盗摄精品一区二区三区在线| 欧美影院一区二区| 中文字幕一区二区三区色视频| 另类欧美日韩国产在线| 欧美午夜不卡在线观看免费| 中文字幕免费不卡| 国产一区二区久久| 欧美电影免费观看高清完整版在线观看| 亚洲图片激情小说| 成人综合在线观看| 精品国一区二区三区| 亚洲高清中文字幕| 在线观看一区二区视频| 国产精品久久99| 国产成人精品亚洲日本在线桃色| 日韩一区二区三区视频在线 | 欧美一级二级三级蜜桃| 一区二区三区在线免费视频| 成人网在线播放| 欧美激情一区二区三区| 高清久久久久久| 欧美国产激情一区二区三区蜜月| 国产一本一道久久香蕉| wwww国产精品欧美| 国产乱妇无码大片在线观看| 日韩欧美国产不卡| 国产一区二区三区免费看| 日韩一区二区视频| 狠狠久久亚洲欧美| 久久久综合网站| 国产精品一级黄| 国产日韩欧美a| 美女视频网站久久| 久久综合一区二区| 国产精品系列在线播放| 国产精品视频第一区| 成人国产视频在线观看| 1024成人网| 色猫猫国产区一区二在线视频| 亚洲色图第一区| 在线观看av一区| 日本亚洲天堂网| 日韩美一区二区三区| 高清av一区二区| 亚洲欧美视频在线观看视频| 欧美色视频一区| 蜜桃久久久久久久| 国产精品丝袜黑色高跟| 欧美视频一区在线| 另类综合日韩欧美亚洲| 久久精品网站免费观看| 99久久综合色| 亚洲国产视频一区二区| 欧美sm极限捆绑bd| 成人午夜视频免费看| 亚洲视频免费观看| 欧美日韩在线三区| 黄页视频在线91| 亚洲欧美综合网| 欧美一区二区三区四区五区| 国产伦精品一区二区三区免费迷 | 亚洲精品成人a在线观看| 欧美男人的天堂一二区| 国产在线播放一区二区三区| 国产精品成人免费| 欧美日韩在线综合| 国产999精品久久| 亚洲va在线va天堂| 欧美激情一区二区三区在线| 欧美三区在线视频| 99久久99精品久久久久久 | 久久久精品国产99久久精品芒果 | 久色婷婷小香蕉久久| 亚洲成人动漫在线观看| 久久不见久久见中文字幕免费| 成人av网站大全| 久久老女人爱爱| 国产一区二区在线电影| 欧美日本一区二区在线观看| 一区二区三区不卡视频在线观看| 91浏览器在线视频| 国产精品你懂的| 99久久国产综合精品麻豆| 国产精品国产三级国产aⅴ入口| 处破女av一区二区| 亚洲视频在线一区观看| 欧美久久一二区| 亚洲精品水蜜桃| 在线观看日韩av先锋影音电影院| 日韩欧美不卡在线观看视频| 国产精品久久久久9999吃药| 国产91精品一区二区麻豆网站| 337p粉嫩大胆色噜噜噜噜亚洲| 欧美性欧美巨大黑白大战| 日韩一级免费观看| 日韩女优av电影| 亚洲成人精品一区二区| 中文字幕亚洲不卡| 久久久777精品电影网影网| 日韩一区二区三区观看| 欧美日韩精品福利| 91福利区一区二区三区| 91丨porny丨户外露出| www.在线欧美| 看电视剧不卡顿的网站| 久久久精品免费网站| 国产不卡视频在线观看| 午夜国产精品影院在线观看| 精品国产成人系列| 成人av网站在线| 久99久精品视频免费观看| 亚洲色图丝袜美腿| 中文字幕欧美日韩一区| 日韩亚洲国产中文字幕欧美| 制服丝袜av成人在线看| 亚洲色图欧美激情| 色国产综合视频| 性感美女极品91精品| 偷拍日韩校园综合在线| 日韩国产精品91| 久久精品国产秦先生| 激情深爱一区二区| 国产成人av自拍| 99免费精品在线| 91久久免费观看| 欧美片网站yy| 久久久亚洲国产美女国产盗摄| 久久久国产午夜精品| 国产精品高清亚洲| 亚洲自拍偷拍图区| 麻豆精品久久久| 国产成人在线免费| 色婷婷综合久久久中文字幕| 欧美在线视频日韩| 宅男噜噜噜66一区二区66| 欧美一区二区三区免费大片| 久久这里只有精品6| 亚洲免费观看高清完整版在线| 亚洲成av人片| 国产一区二区三区电影在线观看| 成人免费毛片高清视频| 91福利小视频| 日韩精品一区二区三区swag| 久久精品欧美一区二区三区麻豆| 日韩毛片视频在线看| 日韩综合小视频| 国产69精品一区二区亚洲孕妇| 91啪九色porn原创视频在线观看| 欧美日韩色综合| 久久网站最新地址| 亚洲美女精品一区| 奇米精品一区二区三区在线观看一| 国产乱色国产精品免费视频| 色婷婷精品久久二区二区蜜臀av| 日韩欧美国产一二三区| 中文字幕av一区二区三区高 | 日韩一级黄色大片| 国产精品国产三级国产普通话99 | 久久精品亚洲精品国产欧美kt∨| 一区二区三区精品视频| 国模套图日韩精品一区二区| 色综合夜色一区| 2021国产精品久久精品| 中文字幕一区二区三区av| 美国精品在线观看| 91蜜桃在线观看| 久久嫩草精品久久久久| 亚洲成av人片www| 91免费视频观看| 国产午夜亚洲精品理论片色戒| 亚洲18色成人| 一本到三区不卡视频| 国产亲近乱来精品视频 | 亚洲欧美另类久久久精品2019| 久草这里只有精品视频| 欧美日韩一级二级三级| 亚洲视频图片小说| 国产一区二区三区蝌蚪| 日韩免费福利电影在线观看| 亚洲一二三四区| 欧美中文字幕一区二区三区亚洲| 久久精品人人做人人综合 | 国产99一区视频免费| 亚洲精品在线免费观看视频| 亚洲精品第1页| 91论坛在线播放| 中文字幕日本不卡| www.成人网.com| 国产精品免费看片| av在线播放一区二区三区| 久久久夜色精品亚洲|