您好,歡迎來電子發(fā)燒友網(wǎng)! ,新用戶?[免費(fèi)注冊(cè)]

您的位置:電子發(fā)燒友網(wǎng)>電子百科>通信技術(shù)>

異構(gòu)信息網(wǎng)絡(luò)構(gòu)建的推薦系統(tǒng)新算法研究

2017年10月10日 11:47 作者: 用戶評(píng)論(0

  在這個(gè)信息多到快要爆炸的時(shí)代,推薦系統(tǒng)在其中承擔(dān)了重大的責(zé)任。不僅能讓用戶更快地獲取有用的信息,同時(shí)也給廠商帶來了另一中的推廣方式,為廠商創(chuàng)造巨大的商業(yè)價(jià)值,現(xiàn)在許多的互聯(lián)網(wǎng)公司都會(huì)有自己的目推薦團(tuán)隊(duì)來從事推薦算法的研究,旨在提升自己的業(yè)務(wù)效果。

  傳統(tǒng)的推薦系統(tǒng)中,最常見的方法就是「協(xié)同過濾」,典型的例子就是我們?cè)陔娚叹W(wǎng)站見到的「購買該商品的用戶也購買了/也在看」。協(xié)同過濾方法一般包括兩種方式,即基于用戶和基于商品的協(xié)同過濾,以及矩陣分解 (Matrix Factorization)。自從 2007 年 Netflix 百萬大獎(jiǎng)的推薦系統(tǒng)比賽以來,矩陣分解的方法開始變得流行。盡管矩陣分解可以獲得不錯(cuò)的推薦效果,但也有明顯的問題:

  1)稀疏性(Sparsity)?,F(xiàn)實(shí)生活里的評(píng)分矩陣往往非常稀疏,因?yàn)閱蝹€(gè)用戶評(píng)分的商品是非常少的;

  2)冷啟動(dòng)(Cold Start)。新產(chǎn)生的用戶和商品往往都沒有評(píng)分。

  上述兩種情況都會(huì)嚴(yán)重影響矩陣分解的預(yù)測準(zhǔn)確性。

  除了這兩個(gè)基本的問題以外,矩陣分解還有一個(gè)更嚴(yán)重的問題:它很難適應(yīng)現(xiàn)在的推薦系統(tǒng)。因?yàn)楫?dāng)下的推薦系統(tǒng)需要處理的特征并非只有評(píng)分信息,而是各種各樣的信息(稱作 Side Information),比如商品的描述,圖片,用戶的好友關(guān)系等。我們可以看圖 1 的例子,這是 Yelp 上一個(gè)餐館的詳情頁。

  

  圖 1:Yelp 上的一個(gè)詳情頁,Royal House

  從圖中,我們可以看到,除了評(píng)分信息之外,還有餐館的地理位置,用戶上傳的圖片,評(píng)論等信息。顯然,在給用戶推薦餐館的過程中,這些信息都非常重要,但它們又很難融入到現(xiàn)有的矩陣分解的模型中。因此,我們需要一個(gè)全新的框架來解決這樣的問題。這是我們此次 KDD 工作的核心思想:「我們用 HIN 來對(duì) side information 進(jìn)行建模,同時(shí)設(shè)計(jì)了一套有效的算法框架,從而獲得更好的推薦效果」。

  算法框架

  預(yù)備知識(shí)

  異構(gòu)信息網(wǎng)絡(luò) (Hetegeneous Information Network 以下簡稱 HIN),是由 UIUC 的 Han Jiawei 和 UCLA 的 Sun Yizhou 在 2011 年的 VLDB 論文中首次提出 [1]。

  簡單地理解,HIN 就是一個(gè)有向圖,圖中的節(jié)點(diǎn)和邊都可以有不同的類型,如下圖,是一個(gè)從上面 Yelp 詳情頁抽取出來的 HIN。節(jié)點(diǎn)可以代表不同類型的實(shí)體,比如 user, review, restaurant 等, 邊代表不同類型的關(guān)系,比如 Check-in, Write, Mention 等。

  異構(gòu)信息網(wǎng)絡(luò)構(gòu)建的推薦系統(tǒng)新算法研究

?

  利用 HIN,我們就可以將各種各樣的 side information 統(tǒng)一起來,接下來我們將介紹如何在 HIN 這個(gè)框架下完成我們的推薦過程。

  從meta-path到meta-graph

  在Sun Yizhou的VLDB2011的論文中,除了提出HIN,同時(shí)也提出了meta-path,用來計(jì)算兩個(gè)節(jié)點(diǎn)之間的相似度。meta-path就是一個(gè)節(jié)點(diǎn)的sequence,節(jié)點(diǎn)與節(jié)點(diǎn)之間由不同類型的邊連接,也就是不同的關(guān)系。

  比如從上圖中的HIN,我們可以設(shè)計(jì)meta-path:

  

  它表示的意義就是兩個(gè)用戶在同一個(gè)餐館簽到。

  我們可以提取一條meta-path的實(shí)例:

  

  那我們可以衡量和 Bar Louie 之間的相似度,當(dāng)有越多的meta-path實(shí)例來連接和 Bar Louie,它們之間的相似度就越大,我們也會(huì)可以給推薦 Bar Louie。我們可以發(fā)現(xiàn),這條 meta-path 正好對(duì)應(yīng)我們熟悉的「基于用戶的協(xié)同過濾」,即經(jīng)常去 Royal House 的人也會(huì)去 Bar Louie。

  從這個(gè)例子我們可以看出,對(duì)于推薦系統(tǒng)來說,HIN和meta-path有兩個(gè)好處:

  1) 非常完美地將各種side information融入到一個(gè)統(tǒng)一的模型;

  2)利用meta-path,可以設(shè)計(jì)出各種各樣的推薦策略,除了推薦準(zhǔn)確性提升之外,還能提供「可解釋性」。

  當(dāng)然,在計(jì)算節(jié)點(diǎn)相似度這個(gè)任務(wù)上,meta-path也有自己的問題:「無法處理復(fù)雜的關(guān)系」。比如兩個(gè)用戶之間有如下連接性。

  異構(gòu)信息網(wǎng)絡(luò)構(gòu)建的推薦系統(tǒng)新算法研究

?

  對(duì)應(yīng)到圖上的實(shí)例, 和 分別給 Royal House 寫了一個(gè)評(píng)論,不僅給了五星好評(píng),還在評(píng)論里同時(shí)提到了這里的「Seafood」,可以說這兩個(gè)用戶對(duì)餐館的偏好非常相似。但是這樣一種相似性,meta-path 無法對(duì)其進(jìn)行建模。為了解決這個(gè)問題,有兩篇論文 ( KDD 16 [2] 和 ICDE 16 [3]) 提出了一種更為通用通用的結(jié)構(gòu): meta-graph(也叫 meta-Structure)。相比 meta-path 要求必須是 sequence 的結(jié)構(gòu),meta-graph 只要求「一個(gè)起點(diǎn)和一個(gè)終點(diǎn),中間結(jié)構(gòu)并不限制」,這樣大大提升了靈活性。因此,在我們的 KDD 論文中,我們采用了 meta-graph 這樣一種結(jié)構(gòu),來計(jì)算用戶和商品之間的相似度。在實(shí)踐中,我們可以設(shè)計(jì) 條 meta-graph,從而得到多種商品和用戶之間的相似度,也就是 個(gè)相似度矩陣。

  推薦過程: 矩陣分解(MF) + 分解因子機(jī)(Factorization Machine)

  通過HIN和mega-graph,我們完美地將各種各樣的side information統(tǒng)一到一個(gè)框架中。接下來的問題就是「如何設(shè)計(jì)更好的推薦算法」。在這個(gè)論文里,我們用到了「MF + FM」的框架,簡單來說: 分別對(duì)個(gè)相似度矩陣進(jìn)行矩陣分解,得到組用戶和商品的隱式特征,然后將所有的特征拼起來,使用分解因子機(jī)進(jìn)行訓(xùn)練和評(píng)分預(yù)測。

  對(duì)于一個(gè)樣本,即用戶-商品對(duì),我們分別可以得到組特征,每組的維度為(在矩陣分解的時(shí)候,我們?cè)O(shè)定秩為)。那么我們就可以拼出下圖中所以的一個(gè)維度為的特征向量。

  異構(gòu)信息網(wǎng)絡(luò)構(gòu)建的推薦系統(tǒng)新算法研究

  Factorization Machine (FM) [4] 是 2010 年在 ICDM 上提出一種模型,由于可以對(duì)特征之間的高階關(guān)系進(jìn)行建模,以及對(duì)二階參數(shù)進(jìn)行低秩分解,因而在評(píng)分預(yù)測這個(gè)推薦任務(wù)上取得了非常好的效果。在實(shí)踐中,我們一般使用二階關(guān)系:

  

  其中,是一階參數(shù),是二階參數(shù)。為了學(xué)出 和,我們使用了 Least Squared loss:

  

  特征選擇: Group Lasso

  一般在 FM 的訓(xùn)練過程中,往往也會(huì)加上和的正則項(xiàng)來防止過擬合,用的最多的就是 。但是,在我們的工作中,由于我們會(huì)設(shè)計(jì)多條 meta-graph,并不是每條 meta-graph 都有用,為了自動(dòng)選擇出有用的 meta-graph,我們放棄了,而選擇,也稱作 group lasso。在我們的算法框架中,我們是以 meta-graph 為單位來構(gòu)造用戶和商品的隱式特征的,因此,每條 meta-graph 對(duì)應(yīng)一組用戶和商品的隱式特征。一旦某條 meta-graph 沒有用,那么它對(duì)應(yīng)的一組特征都應(yīng)該被去掉,這就是我們采用 group lasso 來做正則項(xiàng)的動(dòng)機(jī)。

  使用 group lasso 正則項(xiàng)之后,目標(biāo)函數(shù)優(yōu)化就變成了一個(gè)非凸非光滑(non-convex, non-smooth)的問題,我們使用了鄰近梯度算法(proximal gradient)算法來求解它。

  以上就是我們的算法框架,接下來,我們將通過部分實(shí)驗(yàn)結(jié)果,來證明我們算法的優(yōu)勢。

  實(shí)驗(yàn)結(jié)果

  數(shù)據(jù)集和評(píng)估標(biāo)準(zhǔn)

  我們使用了 Yelp 和 Amazon 這兩個(gè)數(shù)據(jù)集,這兩個(gè)都是非常經(jīng)典的推薦系統(tǒng)數(shù)據(jù)集,同時(shí)也包含了豐富的 side information。數(shù)據(jù)的具體統(tǒng)計(jì)數(shù)據(jù),可以參看我們的論文,這里只展示我們用到的 meta-graph,如下圖。在 Yelp 上,我們?cè)O(shè)計(jì)了 9 條 meta-graph,在 amazon 上,我們?cè)O(shè)計(jì)了 6 種 meta-graph。

  異構(gòu)信息網(wǎng)絡(luò)構(gòu)建的推薦系統(tǒng)新算法研究

?

  在推薦系統(tǒng)中,我們一般用來評(píng)估評(píng)分預(yù)測的好壞,越小意味著推薦效果越好。

  

  其中,是實(shí)際評(píng)分,是預(yù)測評(píng)分,是 test set 的個(gè)數(shù)。

  推薦效果

  在實(shí)驗(yàn)中,我們和一些常見的方法相比,包括基于矩陣分解和基于HIN的方法。具體結(jié)果如下圖:

  異構(gòu)信息網(wǎng)絡(luò)構(gòu)建的推薦系統(tǒng)新算法研究

?

  上圖中,RegSVD 和 FMR 是基于矩陣分解的方法,HeteRec [5] 和 SemRec [6] 分別是 WSDM14 和 CIKM15 上的兩篇論文,在 HIN 上用 meta-path 來進(jìn)行推薦,F(xiàn)MG 是我們的算法。另外,CIKM-Yelp 和 CIKM-Douban 兩個(gè)數(shù)據(jù)集是 CIKM15 的作者 Shi Chuan 提供給我們的。根據(jù)上圖,我們有以下發(fā)現(xiàn):

  在所有的數(shù)據(jù)集上,F(xiàn)MG 打敗了所有的方法,推薦效果取得了不同程度的提升,證明了我們算法的有效性。

  在 CIKM-Yelp 和 CIKM-Douban 這兩個(gè)數(shù)據(jù)集,我們使用和 CIKM15 一樣的 meta-path,依然取得了 4.2% 和 3.2% 的提升,進(jìn)一步證明在 HIN 這個(gè)框架下,我們推薦算法的有效性。

  在兩種基于 HIN 的方法中,我們發(fā)現(xiàn) SemRec 比 HeteRec 的效果好不少。除去推薦算法的差異,一個(gè)重要的不同就是,在 SemRec 中,作者設(shè)計(jì)了 U→?←U→B 這樣形式的 meta-path,而在 HeteRec,作者使用了 U→B←?→B 這樣形式的 meta-path。在我們的算法中,最終選擇出來有效的 meta-graph,大多就是 U→?←U→B 這樣的形式。這個(gè)發(fā)現(xiàn)非常有意思,說明通過「用戶協(xié)同」的推薦結(jié)果效果會(huì)更好一些。這個(gè)發(fā)現(xiàn)也和現(xiàn)實(shí)生活中對(duì)應(yīng),我們獲取感興趣的商品或者餐館,除了興趣本身之外,更多的時(shí)候是通過朋友圈里好友推薦而發(fā)現(xiàn)。它反過來也能解釋 SemRec 好于 HeteRec。

  總結(jié)

  近些年,由于移動(dòng)互聯(lián)網(wǎng)和大數(shù)據(jù)的發(fā)展,現(xiàn)在的推薦系統(tǒng)面臨豐富side information場景,傳統(tǒng)的基于矩陣分解的方法已經(jīng)很難再發(fā)揮作用,而基于人工設(shè)計(jì)的特征工程又極其費(fèi)勁。通過HIN和meta-graph,我們提供了一種簡單有效的框架,既能夠非常靈活地利用side information來提升推薦效果,同時(shí),還能利用人工設(shè)計(jì)的meta-graph來保留必要的語義信息,從而對(duì)推薦結(jié)果提供一定的「可解釋性」。通過實(shí)驗(yàn),我們也證明了這個(gè)框架的有效性。

非常好我支持^.^

(2) 100%

不好我反對(duì)

(0) 0%

( 發(fā)表人:黃昊宇 )

      發(fā)表評(píng)論

      用戶評(píng)論
      評(píng)價(jià):好評(píng)中評(píng)差評(píng)

      發(fā)表評(píng)論,獲取積分! 請(qǐng)遵守相關(guān)規(guī)定!

      ?