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

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

?? formfptree.cs

?? fp-growth算法 用vb.net2005 實現
?? CS
字號:
using System;
using System.Collections;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.IO;

namespace FPTree
{
    /// <summary>
    /// FPTree獲取頻繁模式
    /// </summary>
    public partial class FormFPTree : Form
    {
        /// <summary>
        /// 最小支持度計數
        /// </summary>
        static int MinSupCount = 1000;
        /// <summary>
        /// 最小支持度
        /// </summary>
        static int MinSupPercent = 8;
        /// <summary>
        /// 事務數據庫中的所有事務總數
        /// </summary>
        static int TotalItems = 0;
        /// <summary>
        /// 測試集的文件名
        /// </summary>
        static string _testSet = "";
        


        #region 測試數據集路徑
        static string TestData1 = Application.StartupPath + "\\testdata1_for_FP.dat";
        static string TestData2 = Application.StartupPath + "\\testdata2_for_FP.dat";
        static string TestData3 = Application.StartupPath + "\\testdata3_for_FP.dat";        
        #endregion

       
        public FormFPTree()
        {
            InitializeComponent();
            cbMinSupPercent.SelectedIndex = 0;
        }
       
        /// <summary>
        /// 分析數據
        /// </summary>
        /// <param name="_dataSetFileName"></param>
        private void DoAnalysis(string _dataSetFileName)
        {
            //FPTree
            FPTree _fpTree = new FPTree();
            //FPTree挖掘
            FPGrowthFacade _fpGrowthFacade = new FPGrowthFacade();    

            DateTime _dateTimeStart = DateTime.Now; 
            //讀取數據集,并遍歷取得頻繁一項集
            ReadFile(_dataSetFileName, _fpTree);

            _fpTree.InitializeFPTree();
          
            _fpGrowthFacade.FPGrowth(_fpTree, null);

            _content.Text = "";

            if (_fpGrowthFacade.FrequentPattern.Count > 0)
            {
                DateTime _dateTimeEnd = DateTime.Now;
                TimeSpan _span = (_dateTimeEnd - _dateTimeStart);
                _content.Text += "程序分析總時間:" + _span.TotalSeconds.ToString() + "\r\n" +
                "支持度閥值設置:計數" + MinSupCount + ",支持度" + Math.Round((float)MinSupCount / TotalItems, 3) * 100 + "%\r\n\r\n";                

                foreach (DictionaryEntry _entry in _fpGrowthFacade.FrequentPattern)
                {
                    List<ItemSet> _tmpItemSetList = (List<ItemSet>)_fpGrowthFacade.FrequentPattern[_entry.Key];
                    _content.Text += "頻繁" + _entry.Key + "項集" + _tmpItemSetList.Count+ "個\r\n";
                    
                    foreach (ItemSet _itemSet in _tmpItemSetList)
                    {
                        string[] _contents = new string[_itemSet.Content.Count];
                        _itemSet.Content.CopyTo(_contents);
                        _content.Text += ShowInOrder(_fpTree, _contents) + " (計數" + _itemSet.Count + 
                            ",支持度" + Math.Round((float)_itemSet.Count / TotalItems,3)*100 +"%)\r\n";
                    }
                }
                _content.Text += "頻繁一項集" + _fpTree.FrequentItemCount + "個:\r\n";
                foreach (DictionaryEntry _entry in _fpTree.HashFrequentItemTable)
                {
                    _content.Text += _entry.Key + " (計數" + _entry.Value.ToString() +
                        ",支持度" + Math.Round((float)Convert.ToInt32(_entry.Value) / TotalItems, 3) * 100 + "%)\r\n";
                }
            }
            _fpTree.DisposeAll();
            _fpGrowthFacade.DisposeAll();
        }
        /// <summary>
        /// 按順序顯示字符
        /// </summary>
        /// <param name="_fpTree"></param>
        /// <param name="_contents"></param>
        /// <returns></returns>
        private string ShowInOrder(FPTree _fpTree,string[] _contents)
        {
            int[] _indexs = new int[_contents.Length];
            for (int i = 0; i < _indexs.Length; i++)
            {
                _indexs[i] = _fpTree.GetSupCountByID(_contents[i]);
            }
            int count = _indexs.Length;
            for (int bubble = 0; bubble < count; bubble++)
            {
                for (int lookup = bubble + 1; lookup < count; lookup++)
                {
                    //小的計數往下排
                    if (_indexs[bubble] <
                        _indexs[lookup])
                    {
                        string temp = _contents[bubble];
                        _contents[bubble] = _contents[lookup];
                        _contents[lookup] = temp;
                    }
                }
            }
            string _tmpContents = "";
            for (int i = 0; i < _contents.Length; i++)
            {
                _tmpContents += _contents[i] +" ";
            }
            return _tmpContents;
        }

        #region 系統方法
        private void button1_Click(object sender, EventArgs e)
        {
            if (TotalItems == 0)
            {
                MessageBox.Show("請先預處理數據,以計算事務總數", "系統提示");
                return;
            }

            SetFilePath();
            SetMinSupPercent();
            if (_testSet != "")
                DoAnalysis(_testSet);
            flowLayoutPanel1.Enabled = true;
            TotalItems = 0;
        }
        
       
        private void toolStripButton2_Click(object sender, EventArgs e)
        {
            Close();
        }
        private void toolStripButton3_Click(object sender, EventArgs e)
        {
            SetFilePath();
            //預處理,計算事務總項數
            flowLayoutPanel1.Enabled = false;
            StreamReader sr = new StreamReader(_testSet, System.Text.Encoding.Default);
            while (sr.Peek() >= 0)
            {
                //讀取當前行
                sr.ReadLine();
                TotalItems++;
            }
            sr.Close();
        }
        /// <summary>
        /// 設置數據所在位置
        /// </summary>
        private void SetFilePath()
        {
            if (smallSet.Checked)
                _testSet = TestData1;
            if (bigSet.Checked)
                _testSet = TestData2;
            if (standardSet.Checked)
                _testSet = TestData3;
        }
        /// <summary>
        /// 設計支持度
        /// </summary>
        private void SetMinSupPercent()
        {          
            MinSupPercent = Convert.ToInt32(
                cbMinSupPercent.SelectedItem.ToString().Replace("%",""));
        }       
        #endregion

        #region 讀取數據集,并遍歷取得頻繁一項集
        public void ReadFile(string strFileName, FPTree _fpTree)
        {
            //設置支持度計數
            MinSupCount = Convert.ToInt32(MinSupPercent) * TotalItems / 100;

            StreamReader sr = new StreamReader(strFileName, System.Text.Encoding.Default);
            string  sLineString = "";                     
            
            string[] _arrItemName = null;
            string _itemName = null;
           
            //設置測試數據集開始位置
            int _start = 0;
            if (_testSet == TestData1)
                _start = 1;
            //用Hashtable來保存一項集
            Hashtable _hashTable = new Hashtable();
            List<List<ItemInfo>> _listStrList = new List<List<ItemInfo>>();
                      
            while (sr.Peek() >= 0)
            {                
                //讀取當前行
                sLineString = sr.ReadLine();
                //提取當前行的數組
                _arrItemName = sLineString.Split(new Char[] { ' ' }, 
                    StringSplitOptions.RemoveEmptyEntries);
                //將數組放到內存中
                //_arrStrList.Add(_arrItemName);
                List<ItemInfo> _listItemName = new List<ItemInfo>();
                //將頻繁項集合放到Hashtable中

                for (int i = _start; i < _arrItemName.Length; i++)
                {                    
                    _itemName = _arrItemName[i];                     
                    _listItemName.Add(
                        new ItemInfo(_itemName,0));
                    int _count = 1;
                    if (_hashTable.ContainsKey(_itemName))
                    {
                        _count = Convert.ToInt32(_hashTable[_itemName]) + 1;
                        _hashTable[_itemName] = _count;                       
                    }
                    else
                        _hashTable.Add(_itemName, _count);
                    //頻繁
                    if (_count > MinSupCount - 1)
                    {
                        _fpTree.BuildFrequentItemList(_itemName, _count);
                    }
                }
                _listStrList.Add(_listItemName); //對FPTree傳參
                
            }
            _fpTree.ListStrList = _listStrList; 
            //設置支持度
            _fpTree.MinSupCount = MinSupCount; //對FPTree傳參
            sr.Close();
        }
        #endregion         

       
    }
    
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产不卡一区视频| 欧美三级视频在线| 久久综合av免费| 日本大胆欧美人术艺术动态| 欧美久久久久中文字幕| 日韩1区2区3区| 日韩欧美一区二区久久婷婷| 国内精品写真在线观看| 久久毛片高清国产| 播五月开心婷婷综合| 亚洲欧美日韩精品久久久久| 色婷婷综合五月| 无吗不卡中文字幕| 日韩欧美国产一二三区| 国产91色综合久久免费分享| 亚洲另类春色校园小说| 欧美二区乱c少妇| 韩国视频一区二区| 亚洲图片欧美激情| 欧美色偷偷大香| 国内精品第一页| 国产精品家庭影院| 欧美精品黑人性xxxx| 日本美女视频一区二区| 国产精品久久久久婷婷二区次| 色网站国产精品| 日韩不卡在线观看日韩不卡视频| 2020国产成人综合网| 91香蕉视频在线| 久久电影网站中文字幕| 亚洲欧美一区二区三区极速播放| 欧美男男青年gay1069videost| 久久爱www久久做| 亚洲视频在线观看一区| 欧美大片免费久久精品三p| 波波电影院一区二区三区| 日韩在线a电影| 国产精品蜜臀av| 欧美一区二区三区免费视频| 91在线观看下载| 久久66热偷产精品| 亚洲成在人线在线播放| 久久精品夜色噜噜亚洲a∨| 欧美性淫爽ww久久久久无| 国产一区二区毛片| 亚洲18女电影在线观看| 国产精品欧美一区二区三区| 日韩天堂在线观看| 色综合欧美在线| 国产一区二区三区四区五区入口 | 欧美精品三级日韩久久| 99精品偷自拍| 国产精品1区2区| 青青草国产成人99久久| 一区二区视频在线| 日本一区免费视频| 欧美tk—视频vk| 欧美日韩小视频| 91视频在线看| 成人av电影在线网| 国产精品亚洲视频| 国产伦精一区二区三区| 美女网站色91| 日本欧美大码aⅴ在线播放| 亚洲不卡一区二区三区| 亚洲黄色尤物视频| 一区二区三区四区视频精品免费| 国产视频视频一区| 国产人妖乱国产精品人妖| 精品国产百合女同互慰| 日韩免费一区二区三区在线播放| 欧美日韩日日摸| 欧美日韩aaaaaa| 欧美日韩一级视频| 国产清纯在线一区二区www| 91精品国产综合久久久久| 欧美影院一区二区| 欧美亚洲国产bt| 欧美日韩一区二区三区四区| 色噜噜偷拍精品综合在线| 99精品1区2区| 91理论电影在线观看| 91网页版在线| 欧美主播一区二区三区| 日本道色综合久久| 欧美色倩网站大全免费| 欧美高清精品3d| 另类小说欧美激情| 亚洲国产高清不卡| 精品久久免费看| 久久亚洲综合色一区二区三区 | 欧美va天堂va视频va在线| 欧美精品一区二区在线观看| 91精品国产乱| 欧美一区二区三区在线观看视频| 欧美精品九九99久久| 欧美精品在线观看播放| 欧美丝袜自拍制服另类| 欧美日韩精品一区二区| 日韩一区二区在线观看视频 | 综合在线观看色| 亚洲素人一区二区| 国产精品国产三级国产aⅴ无密码| 国产精品婷婷午夜在线观看| 久久免费看少妇高潮| 欧美激情一区在线| 日本一区二区成人| 最新中文字幕一区二区三区| 欧美国产一区视频在线观看| 亚洲精品视频免费看| 一个色妞综合视频在线观看| 亚洲国产精品久久人人爱| 1024亚洲合集| 亚欧色一区w666天堂| 青娱乐精品视频| 久久99精品国产.久久久久| 国产一区二三区| 久久国产精品72免费观看| 国精产品一区一区三区mba桃花| 精品一区二区三区视频在线观看| 成人教育av在线| 欧美日韩亚洲另类| 久久亚洲精品国产精品紫薇| 欧美国产综合色视频| 一区二区三区不卡视频| 一区二区三区高清在线| 国产成人亚洲综合a∨猫咪| 97久久精品人人澡人人爽| 欧美日韩国产一级片| 精品国产乱码久久久久久闺蜜| 中文字幕免费一区| 亚洲va欧美va人人爽| 成人激情黄色小说| 欧美日韩精品一区二区在线播放| 欧美大片一区二区| 亚洲人成在线观看一区二区| 视频一区视频二区中文| 国产高清视频一区| 在线看一区二区| 久久久久久亚洲综合影院红桃 | 26uuu欧美| 亚洲最大色网站| 国内精品伊人久久久久影院对白| 在线亚洲免费视频| 久久综合狠狠综合久久综合88| 专区另类欧美日韩| 免费看欧美女人艹b| 99re视频精品| 精品国产91久久久久久久妲己| 亚洲国产精华液网站w| 日韩激情中文字幕| 99热精品一区二区| 欧美成人国产一区二区| 亚洲一区二区三区在线| 人人超碰91尤物精品国产| 91国产福利在线| 欧美激情在线看| 精品一区二区三区在线观看 | 欧美视频中文字幕| 国产精品午夜在线观看| 免费精品视频最新在线| 欧美日韩一区在线| 日韩理论片一区二区| 国产一区二区免费在线| 6080日韩午夜伦伦午夜伦| 亚洲区小说区图片区qvod| 国产美女精品人人做人人爽| 日本高清不卡aⅴ免费网站| 国产亚洲欧洲997久久综合| 肉色丝袜一区二区| www.欧美.com| 国产精品高潮呻吟久久| 国产精品一级黄| 久久色.com| 国产乱一区二区| 2020日本不卡一区二区视频| 蜜桃av一区二区| 欧美理论片在线| 亚洲一区二区三区激情| 色综合久久综合网| 亚洲蜜臀av乱码久久精品蜜桃| 高清国产一区二区| 日韩一级二级三级精品视频| 一区二区在线免费观看| 99精品视频一区二区| 中文字幕在线观看不卡| 成人性生交大片| 精品国产乱码久久久久久牛牛| 精品在线亚洲视频| 欧美巨大另类极品videosbest | 亚洲444eee在线观看| 欧美日韩成人在线一区| 亚洲成精国产精品女| aa级大片欧美| 亚洲精品综合在线| 在线视频一区二区免费| 亚洲高清在线视频| 日韩一区二区中文字幕| 亚洲成人三级小说| 欧美午夜片在线观看|