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

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

?? eclat.cpp

?? clique code with sample data set. clique is a data clustering algorithm which follows hierarchical c
?? CPP
字號:
#ifdef __GNUC__
#include <unistd.h>
#endif

#include<iostream>
#include <stdio.h>
#include <list>

//headers
#include "eclat.h"
#include "calcdb.h"
#include "eqclass.h"
#include "stats.h"
#include "chashtable.h"
#include "../code/KCUtility.h"

//global vars
char infile[300];
Dbase_Ctrl_Blk *DCB;
Stats stats;
vector<vector<int> > v_freqsets;

double MINSUP_PER;
int MINSUPPORT=-1;
int DBASE_MAXITEM;
int DBASE_NUM_TRANS;

//default flags
bool output = false; //don't print freq itemsets
bool output_idlist = false; //don't print idlist

diff_vals diff_type = diff; //default is diffset mode
diff_vals max_diff_type = nodiff; //deafult is to use tidsets for maxtest
sort_vals sort_type = incr; //default is to sort in increasing order
alg_vals alg_type = eclat; //default is to find all freq patterns
closed_vals closed_type = cnone; //default is not to eliminate non-closed
prune_vals prune_type = noprune; //default no pruning

//extern functions
extern void enumerate_max_freq(Eqclass *eq, int iter, idlist &newmax);
extern void enumerate_max_closed_freq(Eqclass *eq, int iter, idlist &newmax);
extern void enumerate_closed_freq(Eqclass *eq, int iter, idlist &newmax);
extern void enumerate_freq(Eqclass *eq, int iter);
extern void form_closed_f2_lists(Eqclass *eq);
extern void form_f2_lists(Eqclass *eq);
extern cHashTable hashtest; //for closed (with chash) testing

//ostream & operator<<(ostream& fout, vector<int> &vec){
//  for (unsigned int i=0; i < vec.size(); ++i)
//     fout << vec[i] << " ";
//  return fout;
//}


void get_F1()
{
  double te = 0.0;

  int i, j, it;
  const int arysz = 10;
  
  vector<int> itcnt(arysz,0); //count item frequency

  DBASE_MAXITEM=0;
  DBASE_NUM_TRANS = 0;
  
  DCB->Cidsum = 0;
  
   while(DCB->get_next_trans())
   {
      for (i=0; i < DCB->TransSz; ++i)
      {
         it = DCB->TransAry[i];

         if (it >= DBASE_MAXITEM)
         {
            itcnt.resize(it+1,0);
            DBASE_MAXITEM = it+1;
         }
         ++itcnt[it];
      }
      
      if (DCB->MaxTransSz < DCB->TransSz) DCB->MaxTransSz = DCB->TransSz;     
      ++DBASE_NUM_TRANS;
      DCB->Cidsum += DCB->Cid; //used to initialize hashval for closed set mining
   }

   //set the value of MINSUPPORT
   if (MINSUPPORT == -1)
      MINSUPPORT = (int) (MINSUP_PER*DBASE_NUM_TRANS+0.5);
   
   if (MINSUPPORT<1) MINSUPPORT=1;
   //cout<<"DBASE_NUM_TRANS : "<< DBASE_NUM_TRANS << endl;
   //cout<<"DBASE_MAXITEM : "<< DBASE_MAXITEM << endl;
   //cout<<"MINSUPPORT : "<< MINSUPPORT << " (" << MINSUP_PER << ")" << endl;

   //count number of frequent items
   DCB->NumF1 = 0;
   for (i=0; i < DBASE_MAXITEM; ++i)
      if (itcnt[i] >= MINSUPPORT)
         ++DCB->NumF1;

   //construct forward and reverse mapping from items to freq items
   DCB->FreqIdx = new int [DCB->NumF1];
   DCB->FreqMap = new int [DBASE_MAXITEM];
   for (i=0,j=0; i < DBASE_MAXITEM; ++i) 
   {
      if (itcnt[i] >= MINSUPPORT) 
      {
         //if (output && alg_type == eclat) 
            //cout << i << " - " << itcnt[i] << endl;
         DCB->FreqIdx[j] = i;
         DCB->FreqMap[i] = j;
         ++j;
      }
      else DCB->FreqMap[i] = -1;
   }
   
   DCB->alloc_ParentClass(itcnt);
   
   stats.add(DBASE_MAXITEM, DCB->NumF1, te);
}

list<Eqclass *> * get_F2()
{
  int i,j;
  int it1, it2;
  vector<int> freqsets;
  
  double te = 0.0;

  list<Eqclass *> *F2list = new list<Eqclass *>;

  //itcnt2 is a matrix of pairs p, p.first is count, p.second is flag
  int **itcnt2 = new int*[DCB->NumF1];

  //unsigned int **itcnt2 = new unsigned int *[DCB->NumF1];
  for (i=0; i < DCB->NumF1; ++i)
  {
    itcnt2[i] = new int [DCB->NumF1];
    for (j=0; j < DCB->NumF1; ++j)
      itcnt2[i][j] = 0;
  }
    
   while(DCB->get_next_trans())
   {
      DCB->get_valid_trans();
      DCB->make_vertical();
      //count a pair only once per cid
      for (i=0; i < DCB->TransSz; ++i)
      {
         it1 = DCB->TransAry[i];
         for (j=i+1; j < DCB->TransSz; ++j)
         {
            it2 = DCB->TransAry[j];
            ++itcnt2[it1][it2];
         }
      }
   }                           

   //compute class size
   DCB->class_sz = new int[DCB->NumF1];
   DCB->F2sum = new int[DCB->NumF1];
   for (i=0; i < DCB->NumF1; ++i)
   {
      DCB->class_sz[i] = 0;
      DCB->F2sum[i] = 0;
   }
   
   for (i=0; i < DCB->NumF1; ++i)
   {
      for (j=i+1; j < DCB->NumF1; ++j)
      {
         if (itcnt2[i][j] >= MINSUPPORT)
         {
            ++DCB->class_sz[i];
            ++DCB->class_sz[j];
            DCB->F2sum[i] += itcnt2[i][j];
            DCB->F2sum[j] += itcnt2[i][j];
         }
      }
   }
   
   DCB->sort_ParentClass();
   
   int F2cnt=0;

   // count frequent patterns and generate eqclass
   Eqclass *eq;
   int sup;
   for (i=0; i < DCB->NumF1; ++i) 
   {
      eq = new Eqclass;
      eq->prefix().push_back(i);
      it1 = DCB->ParentClass[i]->val;
      for (j=i+1; j < DCB->NumF1; ++j) 
      {
         it2 = DCB->ParentClass[j]->val;
         if (it1 < it2) sup = itcnt2[it1][it2];
         else sup = itcnt2[it2][it1];
         if (sup >= MINSUPPORT)
         {
            ++F2cnt;
	        eq->add_node(j);
	        if (output && alg_type == eclat) 
            {
               //cout << DCB->FreqIdx[it1] << " " << DCB->FreqIdx[it2] 
                    //<< " - " << sup << endl;
               freqsets.push_back(sup);
               freqsets.push_back(DCB->FreqIdx[it1]);
               freqsets.push_back(DCB->FreqIdx[it2]);
               v_freqsets.push_back(freqsets);
               freqsets.clear();
            }
         }
      }   
      F2list->push_back(eq);
   }
   
   //remap FreqIdx, FreqMap and ParentClass vals in sorted order
   for (i=0; i < DCB->NumF1; ++i)
      DCB->FreqMap[DCB->FreqIdx[DCB->ParentClass[i]->val]] = i;

   for (i=0; i < DBASE_MAXITEM; ++i)
      if (DCB->FreqMap[i] != -1)
         DCB->FreqIdx[DCB->FreqMap[i]] = i;

   for (i=0; i < DCB->NumF1; ++i)
      DCB->ParentClass[i]->val = i;
   
   for (i=0; i < DCB->NumF1; ++i) 
      delete [] itcnt2[i];
   
   delete [] itcnt2;
   delete [] DCB->class_sz;
   delete [] DCB->F2sum;
   
   stats.add(DCB->NumF1 * DCB->NumF1, F2cnt, te);

   return F2list;
}

//performs l1 intersect l2
subset_vals get_intersect(idlist *l1, idlist *l2, idlist *join, int &idsum, 
                          int minsup=0)
{
   int diffmax1, diffmax2;
   diffmax1 = l1->size() - minsup;
   diffmax2 = l2->size() - minsup;
   
   int diffcnt1 = 0, diffcnt2 = 0;
   int n1, n2;
   unsigned int i1 = 0, i2 = 0;

   idsum = 0;
   while (i1 < l1->size() && i2 < l2->size() && 
          diffcnt1 <= diffmax1 && diffcnt2 <= diffmax2)
   {
      n1 = (*l1)[i1];
      n2 = (*l2)[i2];

      //look for matching cids
      if (n1 < n2)
      {
         ++i1;
         ++diffcnt1;
      }
      else if (n1 > n2)
      {
         ++i2;
         ++diffcnt2;
      }
      else
      {
         join->push_back(n1);
         idsum += n1;
         ++i1;
         ++i2;
      }
   }

   if (i1 < l1->size()) ++diffcnt1;
   if (i2 < l2->size()) ++diffcnt2;
   
   if (diffcnt1 == 0 && diffcnt2 == 0) return equals;
   else if (diffcnt1 == 0 && diffcnt2 > 0) return subset;
   else if (diffcnt1 > 0 && diffcnt2 == 0) return superset;
   else return notequal;   
}

//performs l1 - l2
subset_vals get_diff (idlist *l1, idlist *l2, idlist *join, 
                      int &idsum, int diffmax=INT_MAX)
{
   int n1, n2;
   int diffcnt1 = 0, diffcnt2 = 0;
   unsigned int i1 = 0, i2 = 0;
   
   idsum = 0;

   while (i1 < l1->size() && i2 < l2->size() && diffcnt1 <= diffmax)
   {
      n1 = (*l1)[i1];
      n2 = (*l2)[i2];

      if (n1 < n2)
      {
         //implies that n1 is not to be found in n2
         join->push_back(n1);
         ++diffcnt1;
         idsum += n1;
         
         ++i1;
      }
      else if (n1 > n2)
      {
         ++i2;
         ++diffcnt2;
      }
      else
      {
         ++i1;
         ++i2;
      }
   }   
   
   //add any remaining elements in l1 to join
   while (i1 < l1->size())
   {
      join->push_back((*l1)[i1]);
      idsum += (*l1)[i1];
      ++i1;
      ++diffcnt1;
   }
   
   if (i2 < l2->size()) ++diffcnt2;

   if (diffcnt1 == 0 && diffcnt2 == 0) return equals;
   else if (diffcnt1 == 0 && diffcnt2 > 0) return superset;
   else if (diffcnt1 > 0 && diffcnt2 == 0) return subset;
   else return notequal;   
}

subset_vals get_join(Eqnode *l1, Eqnode *l2, Eqnode *join, int iter)
{
   int diffmax = l1->support()-MINSUPPORT;
   int idsum;

   subset_vals sval = notequal;
 
   //compute tidset or diffset for join of l1 nd l2
   switch (diff_type)
   {
   case diff2:
      if (iter == 2) sval = get_diff(&l1->tidset, &l2->tidset, 
                                     &join->tidset, idsum, diffmax);
      else sval = get_diff(&l2->tidset, &l1->tidset, &join->tidset, 
                           idsum, diffmax);
      if (sval == subset) sval = superset;
      else if (sval == superset) sval = subset;
      join->support() = l1->support() - join->tidset.size();            
      join->hashval() = l1->hashval() - idsum;
      break;
   case nodiff:
      sval = get_intersect(&l1->tidset, &l2->tidset, 
                           &join->tidset, idsum, MINSUPPORT);
      join->support() = join->tidset.size();      
      join->hashval() = idsum;
      break;
   case diffin:
      sval = get_diff(&l2->tidset, &l1->tidset, &join->tidset, idsum, diffmax);
      if (sval == subset) sval = superset;
      else if (sval == superset) sval = subset;
      join->support() = l1->support() - join->tidset.size();            
      join->hashval() = l1->hashval() - idsum;
      break;
   case diff:
      if (iter == 2)
      {
         sval = get_intersect(&l1->tidset, &l2->tidset,
                              &join->tidset, idsum, MINSUPPORT);
         join->support() = join->tidset.size();      
         join->hashval() = idsum;
      }
      else
      {
         if (iter == 3) 
            sval = get_diff(&l1->tidset, &l2->tidset, &join->tidset, 
                            idsum, diffmax);
         else
            sval = get_diff(&l2->tidset, &l1->tidset, &join->tidset, 
                            idsum, diffmax);
         if (sval == subset) sval = superset;
         else if (sval == superset) sval = subset;
         join->support() = l1->support() - join->tidset.size();            
         join->hashval() = l1->hashval() - idsum;
      }
      break;
   }

   ++Stats::numjoin;
   return sval;
}

void get_max_join(Eqnode *l1, Eqnode *l2, Eqnode *join, int iter)
{
   int idsum;
   //find local maximal context for join
   //i.e., which maximal sets contain join as a subset
   switch(max_diff_type){
   case nodiff:
      get_intersect(&l1->maxset, &l2->maxset, &join->maxset, idsum);
      join->maxsupport() = join->maxset.size();  
      break;
   case diff2:
      if (iter == 2) get_diff(&l1->maxset, &l2->maxset, &join->maxset, idsum);
      else get_diff(&l2->maxset, &l1->maxset, &join->maxset, idsum);
      join->maxsupport() = l1->maxsupport() - join->maxset.size();
      break;
   case diffin:
      get_diff(&l2->maxset, &l1->maxset, &join->maxset, idsum);
      join->maxsupport() = l1->maxsupport() - join->maxset.size();
      break;
   case diff:
      exit(-1);
      break;
   }
}

void get_Fk(list<Eqclass *> &F2list){
   Eqclass *eq;
   idlist newmax;
   int iter = 2;
   while(!F2list.empty())
   {
      eq = F2list.front();

      switch(alg_type){
      case eclat:
         form_f2_lists(eq);
         enumerate_freq(eq, iter+1);
         break;
      case charm:
         form_closed_f2_lists(eq);
         newmax.clear();
         enumerate_closed_freq(eq, iter+1, newmax);
         break;
      case basicmax:
         form_f2_lists(eq);
         newmax.clear();
         enumerate_max_freq(eq, iter+1, newmax);
         break;
      case maxcharm:
         form_closed_f2_lists(eq);
         newmax.clear();
         enumerate_max_closed_freq(eq, iter+1, newmax);
         break;
      }      
      delete eq;
      F2list.pop_front();
   }
}                         

vector<vector<int> > get_maxfreqsets(int alnm, char * fname, int difn, double supp)
{
   vector<vector<int> >::iterator vvit;
   vector<int>::iterator vit;
   vector<int> freqsets;
   alg_type = (alg_vals) alnm;
   Dbase_Ctrl_Blk::binary_input = true;
   strcpy(infile, fname);
   diff_type = (diff_vals) difn;
   output = true;
   MINSUP_PER = supp;
   
   DCB = new Dbase_Ctrl_Blk(infile); 
   get_F1();
   list<Eqclass *> *F2list = get_F2();
   get_Fk(*F2list);

   /*for (vvit = v_freqsets.begin(); vvit != v_freqsets.end(); ++ vvit)
   {
      freqsets = *vvit;
      for (vit = freqsets.begin(); vit != freqsets.end(); ++ vit)
         cout << *vit << " ";
      cout << endl;
   }*/
   
   delete DCB;
   return v_freqsets;
}


/*int main(int argc, char **argv)
{
   vector<vector<int> >::iterator vvit;
   vector<int>::iterator vit;
   vector<int> freqsets;
   alg_type = (alg_vals) atoi(argv[1]);
   Dbase_Ctrl_Blk::binary_input = true;
   strcpy(infile, argv[2]);
   diff_type = (diff_vals) atoi(argv[3]);
   output = true;
   MINSUP_PER = atof(argv[4]);
   
   DCB = new Dbase_Ctrl_Blk(infile); 
   get_F1();
   list<Eqclass *> *F2list = get_F2();

   get_Fk(*F2list);

   for (vvit = v_freqsets.begin(); vvit != v_freqsets.end(); ++ vvit)
   {
      freqsets = *vvit;
      for (vit = freqsets.begin(); vit != freqsets.end(); ++ vit)
         cout << *vit << " ";
      cout << endl;
   }
   delete DCB;
   return 0;
}*/



?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
51精品秘密在线观看| 国产成人午夜高潮毛片| 亚洲va韩国va欧美va精品| 亚洲成人在线网站| 欧美日韩国产首页| 日韩写真欧美这视频| 久久久久久久网| 亚洲欧美国产三级| 亚洲国产一区二区在线播放| 精品一区二区三区香蕉蜜桃| 91日韩一区二区三区| 欧美一级夜夜爽| 亚洲激情图片小说视频| 国产精品亚洲成人| 欧美一级片在线观看| 久久99热国产| 欧美顶级少妇做爰| 亚洲卡通欧美制服中文| 欧美日韩国产另类不卡| 黄色精品一二区| 91精品国产全国免费观看| 乱一区二区av| 国产精品美女久久久久久久| 视频一区欧美日韩| 欧美亚洲国产怡红院影院| 久久久久国产一区二区三区四区| 国产高清久久久久| 悠悠色在线精品| 欧美tickling网站挠脚心| 一区二区三区国产精华| 不卡视频一二三四| 久久精子c满五个校花| 久久不见久久见中文字幕免费| 国产欧美一区二区在线| 成人永久免费视频| 日本一区二区综合亚洲| 精品视频在线免费看| 亚洲成人精品一区二区| 久久久久久久久久看片| 欧美日韩一区久久| 国产91丝袜在线播放九色| 中文字幕欧美国产| 成人app网站| 蜜臀久久99精品久久久久久9 | 国产精品麻豆久久久| 色国产综合视频| 一区二区三区在线高清| 久久久久久久久久久久久女国产乱| 99v久久综合狠狠综合久久| 亚洲男人电影天堂| 久久综合狠狠综合久久激情| 国产91精品免费| 日日摸夜夜添夜夜添亚洲女人| 中文字幕中文字幕中文字幕亚洲无线| 成人aaaa免费全部观看| 久久成人免费电影| 亚洲国产成人av网| 中文字幕不卡在线| 久久婷婷综合激情| 欧美一区二区三区在线视频| 在线亚洲免费视频| 久久99国产乱子伦精品免费| 亚洲国产精品一区二区www | 91一区一区三区| 精品在线播放免费| 日本aⅴ精品一区二区三区| 久久九九久久九九| 日韩女优制服丝袜电影| av亚洲精华国产精华精| 亚洲高清免费在线| 一区二区三区四区中文字幕| 国产精品久久久一本精品| 国产日韩精品久久久| 国产日韩欧美精品在线| 国产女主播一区| 欧美激情一区在线观看| 国产欧美一区二区精品性色超碰| 2017欧美狠狠色| 国产色一区二区| 久久―日本道色综合久久| 久久精品一区二区三区av| 欧美精品一区二| 久久久久久夜精品精品免费| 久久久久久综合| 中文字幕中文字幕一区| 一区二区三区中文字幕精品精品| 亚洲欧美另类久久久精品 | 欧美日韩国产高清一区二区| 欧美日韩激情一区二区三区| 欧美日韩国产首页| 日韩欧美的一区| 国产喂奶挤奶一区二区三区| 欧美韩日一区二区三区| 亚洲人成亚洲人成在线观看图片| 亚洲精品一二三| 日韩精品久久久久久| 国内精品伊人久久久久影院对白| 国产综合色精品一区二区三区| 粉嫩av一区二区三区在线播放 | 午夜精品免费在线观看| 久久久久国产成人精品亚洲午夜| 久久精品视频在线免费观看| 国产精品麻豆一区二区| 亚洲中国最大av网站| 国产精品免费视频网站| 成人免费一区二区三区在线观看| 精品国产一区二区在线观看| 欧美嫩在线观看| 久久综合狠狠综合久久综合88| 中文字幕一区日韩精品欧美| 婷婷综合在线观看| 国产精品18久久久久久久久| 91在线观看视频| 日韩一区二区三区四区| 国产精品久久久久9999吃药| 日韩精品国产欧美| 成人免费视频app| 欧美精品123区| 日本一区二区三区四区| 性欧美疯狂xxxxbbbb| 国产精品一区二区在线观看不卡 | 亚洲综合在线观看视频| 韩国精品主播一区二区在线观看| 97久久精品人人做人人爽50路| 7777精品伊人久久久大香线蕉经典版下载 | 日韩美女视频一区二区在线观看| 国产精品无码永久免费888| 午夜精品福利视频网站| 国产精品正在播放| 制服丝袜亚洲精品中文字幕| 国产精品毛片高清在线完整版| 奇米影视一区二区三区| 91视视频在线观看入口直接观看www | 久久精品亚洲乱码伦伦中文| 亚洲成国产人片在线观看| 国产高清精品网站| 欧美一级理论片| 亚洲精品免费播放| 国产suv精品一区二区6| 欧美精品tushy高清| 自拍偷自拍亚洲精品播放| 亚洲免费视频中文字幕| 国产精品99久| 日韩一区国产二区欧美三区| 亚洲欧美日韩中文播放| 国产成人精品综合在线观看| 欧美一区二区精品久久911| 亚洲三级在线免费| 国产a精品视频| 精品久久久久久久一区二区蜜臀| 同产精品九九九| 欧美日韩久久久| 亚洲精选免费视频| 成人理论电影网| 国产欧美日韩另类一区| 国内成+人亚洲+欧美+综合在线| 欧美日韩精品一区二区三区四区 | 99精品视频在线免费观看| 2021久久国产精品不只是精品| 偷拍日韩校园综合在线| 欧美日韩精品专区| 亚洲一区二区三区四区五区中文| 一本久道久久综合中文字幕 | 亚洲色图视频网| 91年精品国产| 亚洲精品videosex极品| 91女人视频在线观看| 亚洲天堂免费看| 色综合久久天天综合网| 自拍av一区二区三区| av中文字幕亚洲| 亚洲乱码国产乱码精品精小说| 成人激情动漫在线观看| 国产精品青草综合久久久久99| 国产成人精品免费| 国产精品麻豆一区二区| 91首页免费视频| 亚洲尤物视频在线| 欧美三级在线看| 免费成人在线网站| 精品国产99国产精品| 粉嫩一区二区三区性色av| 中文字幕乱码久久午夜不卡| 91性感美女视频| 午夜成人在线视频| 欧美成人一区二区三区片免费| 狠狠狠色丁香婷婷综合激情| 久久伊人蜜桃av一区二区| 盗摄精品av一区二区三区| 亚洲少妇屁股交4| 欧美巨大另类极品videosbest| 日韩不卡一二三区| 欧美日韩久久久久久| 蜜臀av国产精品久久久久 | 岛国一区二区在线观看| 亚洲精品视频在线观看免费| 欧美日韩一级二级| 激情综合色综合久久综合| 中文字幕精品一区| 欧美人xxxx|