電商數(shù)據(jù)挖掘:“啤酒+尿布”的關(guān)聯(lián)算法規(guī)則

0 評論 18267 瀏覽 14 收藏 8 分鐘

  關(guān)聯(lián),其實(shí)很簡單,就是幾個東西或者事件是經(jīng)常同時出現(xiàn)的,“啤酒+尿布”就是非常典型的兩個關(guān)聯(lián)商品。

所謂關(guān)聯(lián),反映的是一個事件和其他事件之間依賴或關(guān)聯(lián)的知識。當(dāng)我們查找英文文獻(xiàn)的時候,可以發(fā)現(xiàn)有兩個英文詞都能形容關(guān)聯(lián)的含義。第一個是相關(guān)性relevance,第二個是關(guān)聯(lián)性association,兩者都可以用來描述事件之間的關(guān)聯(lián)程度。其中前者主要用在互聯(lián)網(wǎng)的內(nèi)容和文檔上,比如搜索引擎算法中文檔之間的關(guān)聯(lián)性,我們采用的詞是relevance;而后者往往用在實(shí)際的事物之上,比如電子商務(wù)網(wǎng)站上的商品之間的關(guān)聯(lián)度我們是用association來表示的,而關(guān)聯(lián)規(guī)則是用association rules來表示的。

如果兩項或多項屬性之間存在關(guān)聯(lián),那么其中一項的屬性值就可以依據(jù)其他屬性值進(jìn)行預(yù)測。簡單地來說,關(guān)聯(lián)規(guī)則可以用這樣的方式來表示:A→B,其中A被稱為前提或者左部(LHS),而B被稱為結(jié)果或者右部(RHS)。如果我們要描述關(guān)于尿布和啤酒的關(guān)聯(lián)規(guī)則(買尿布的人也會買啤酒),那么我們可以這樣表示:買尿布→買啤酒。

關(guān)聯(lián)算法的兩個概念

在關(guān)聯(lián)算法中很重要的一個概念是支持度(Support),也就是數(shù)據(jù)集中包含某幾個特定項的概率。

比如在1000次的商品交易中同時出現(xiàn)了啤酒和尿布的次數(shù)是50次,那么此關(guān)聯(lián)的支持度為5%。

和關(guān)聯(lián)算法很相關(guān)的另一個概念是置信度(Confidence),也就是在數(shù)據(jù)集中已經(jīng)出現(xiàn)A時,B發(fā)生的概率,置信度的計算公式是 :A與B同時出現(xiàn)的概率/A出現(xiàn)的概率。

數(shù)據(jù)關(guān)聯(lián)是數(shù)據(jù)庫中存在的一類重要的可被發(fā)現(xiàn)的知識。若兩個或多個變量的取值之間存在某種規(guī)律性,就稱為關(guān)聯(lián)。關(guān)聯(lián)可分為簡單關(guān)聯(lián)、時序關(guān)聯(lián)、因果關(guān)聯(lián)等。關(guān)聯(lián)分析的目的是找出數(shù)據(jù)庫中隱藏的關(guān)聯(lián)網(wǎng)。有時并不知道數(shù)據(jù)庫中數(shù)據(jù)的關(guān)聯(lián)函數(shù),或者即使知道也是不確定的,因此關(guān)聯(lián)分析生成的規(guī)則帶有置信度。

關(guān)聯(lián)規(guī)則挖掘發(fā)現(xiàn)大量數(shù)據(jù)中項集之間有趣的關(guān)聯(lián)或相關(guān)聯(lián)系。它在數(shù)據(jù)挖掘中是一個重要的課題,最近幾年已被業(yè)界所廣泛研究。

關(guān)聯(lián)規(guī)則挖掘的一個典型例子是購物籃分析。關(guān)聯(lián)規(guī)則研究有助于發(fā)現(xiàn)交易數(shù)據(jù)庫中不同商品(項)之間的聯(lián)系,找出顧客購買行為模式,如購買了某一商品對購買其他商品的影響。分析結(jié)果可以應(yīng)用于商品貨架布局、貨存安排以及根據(jù)購買模式對用戶進(jìn)行分類。

關(guān)聯(lián)規(guī)則的發(fā)現(xiàn)過程可分為如下兩步:

第一步是迭代識別所有的頻繁項目集(Frequent Itemsets),要求頻繁項目集的支持度不低于用戶設(shè)定的最低值;

第二步是從頻繁項目集中構(gòu)造置信度不低于用戶設(shè)定的最低值的規(guī)則,產(chǎn)生關(guān)聯(lián)規(guī)則。識別或發(fā)現(xiàn)所有頻繁項目集是關(guān)聯(lián)規(guī)則發(fā)現(xiàn)算法的核心,也是計算量最大的部分。

支持度和置信度兩個閾值是描述關(guān)聯(lián)規(guī)則的兩個最重要的概念。一項目組出現(xiàn)的頻率稱為支持度,反映關(guān)聯(lián)規(guī)則在數(shù)據(jù)庫中的重要性。而置信度衡量關(guān)聯(lián)規(guī)則的可信程度。如果某條規(guī)則同時滿足最小支持度(min-support)和最小置信度(min-confidence),則稱它為強(qiáng)關(guān)聯(lián)規(guī)則。

關(guān)聯(lián)規(guī)則數(shù)據(jù)挖掘階段

第一階段必須從原始資料集合中,找出所有高頻項目組(Large Itemsets)。高頻的意思是指某一項目組出現(xiàn)的頻率相對于所有記錄而言,必須達(dá)到某一水平。以一個包含A與B兩個項目的2-itemset為例,我們可以求得包含{A,B}項目組的支持度,若支持度大于等于所設(shè)定的最小支持度(Minimum Support)門檻值時,則{A,B}稱為高頻項目組。一個滿足最小支持度的k-itemset,則稱為高頻k-項目組(Frequent k-itemset),一般表示為Large k或Frequent k。算法并從Large k的項目組中再試圖產(chǎn)生長度超過k的項目集Large k+1,直到無法再找到更長的高頻項目組為止。

關(guān)聯(lián)規(guī)則挖掘的第二階段是要產(chǎn)生關(guān)聯(lián)規(guī)則。從高頻項目組產(chǎn)生關(guān)聯(lián)規(guī)則,是利用前一步驟的高頻k-項目組來產(chǎn)生規(guī)則,在最小可信度(Minimum Confidence)的條件門檻下,若一規(guī)則所求得的可信度滿足最小可信度,則稱此規(guī)則為關(guān)聯(lián)規(guī)則。

例如:經(jīng)由高頻k-項目組{A,B}所產(chǎn)生的規(guī)則,若其可信度大于等于最小可信度,則稱{A,B}為關(guān)聯(lián)規(guī)則。

就“啤酒+尿布”這個案例而言,使用關(guān)聯(lián)規(guī)則挖掘技術(shù),對交易資料庫中的記錄進(jìn)行資料挖掘,首先必須要設(shè)定最小支持度與最小可信度兩個門檻值,在此假設(shè)最小支持度min-support=5% 且最小可信度min-confidence=65%。因此符合需求的關(guān)聯(lián)規(guī)則將必須同時滿足以上兩個條件。若經(jīng)過挖掘所找到的關(guān)聯(lián)規(guī)則 {尿布,啤酒}滿足下列條件,將可接受{尿布,啤酒} 的關(guān)聯(lián)規(guī)則。用公式可以描述為:

Support(尿布,啤酒)≥5% and Confidence(尿布,啤酒)≥65%。

其中,Support(尿布,啤酒)≥5%于此應(yīng)用范例中的意義為:在所有的交易記錄資料中,至少有5%的交易呈現(xiàn)尿布與啤酒這兩項商品被同時購買的交易行為。Confidence(尿布,啤酒)≥65%于此應(yīng)用范例中的意義為:在所有包含尿布的交易記錄資料中,至少有65%的交易會同時購買啤酒。

因此,今后若有某消費(fèi)者出現(xiàn)購買尿布的行為,我們將可推薦該消費(fèi)者同時購買啤酒。這個商品推薦的行為則是根據(jù){尿布,啤酒}關(guān)聯(lián)規(guī)則而定,因?yàn)榫瓦^去的交易記錄而言,支持了“大部分購買尿布的交易,會同時購買啤酒”的消費(fèi)行為。

從上面的介紹還可以看出,關(guān)聯(lián)規(guī)則挖掘通常比較適用于記錄中的指標(biāo)取離散值的情況。

如果原始數(shù)據(jù)庫中的指標(biāo)值是取連續(xù)的數(shù)據(jù),則在關(guān)聯(lián)規(guī)則挖掘之前應(yīng)該進(jìn)行適當(dāng)?shù)臄?shù)據(jù)離散化(實(shí)際上就是將某個區(qū)間的值對應(yīng)于某個值),數(shù)據(jù)的離散化是數(shù)據(jù)挖掘前的重要環(huán)節(jié),離散化的過程是否合理將直接影響關(guān)聯(lián)規(guī)則的挖掘結(jié)果

更多精彩內(nèi)容,請關(guān)注人人都是產(chǎn)品經(jīng)理微信公眾號或下載App
評論
評論請登錄
  1. 目前還沒評論,等你發(fā)揮!