王 菁,王若飛
(1.大規(guī)模流數(shù)據(jù)集成與分析技術北京市重點實驗室,北京 100144;2.北方工業(yè)大學數(shù)據(jù)工程研究院,北京 100144)
在電子商務以及網(wǎng)頁搜索領域,查詢建議是一個重要的輔助功能[1]。所謂“查詢建議”是指用戶在搜索框輸入查詢詞的同時,會在輸入框的下面彈出一組建議查詢詞,例如搜索“連衣”,會彈出“連衣裙”“黑色連衣裙”“短袖連衣裙”等建議查詢詞供用戶選擇。這一方面可以減少用戶輸入,不需要用戶輸入完整的查詢詞即可得到所需的搜索結果,可帶給用戶便捷的搜索體驗;另一方面也可以有效消除查詢詞不完全,存在同義、歧義等現(xiàn)象,提高信息檢索的準確率。
據(jù)中國互聯(lián)網(wǎng)絡信息中心CNNIC發(fā)布的《第39次中國互聯(lián)網(wǎng)絡發(fā)展狀況統(tǒng)計報告》[2]顯示,截止2016年12月,我國網(wǎng)絡購物用戶規(guī)模達到4.67億,占網(wǎng)民比例為63.8%,較2015年增長12.9%。據(jù)CNNIC調(diào)查顯示:74.3%的用戶習慣通過輸入關鍵字進行檢索,人們輸入檢索關鍵字的平均長度僅為2~3個字。查詢建議即是在用戶輸入的有限、不完整的查詢詞與系統(tǒng)內(nèi)待檢索對象(網(wǎng)頁、商品等)所包含的專業(yè)查詢詞之間建立映射,為非專業(yè)用戶推薦與原始查詢詞相關的專業(yè)查詢詞,從而幫助用戶快速找到所需的結果。
在基于互聯(lián)網(wǎng)的線上購物型應用中,由于沒有傳統(tǒng)行業(yè)的導購與用戶進行面對面交流,用戶只能通過搜索框與系統(tǒng)進行實時交互,查詢建議是否能快速準確地滿足用戶需求對電商應用的用戶體驗具有很重要的影響。由于電子商務領域的特性,提供合適的查詢建議需要解決以下幾方面的問題:
首先,如何構建合適的查詢建議詞庫?用戶輸入的短關鍵字查詢本身由于短關鍵字與檢索系統(tǒng)構造的詞庫不一定完全匹配,容易造成信息檢索不完全不準確。很多研究工作從用戶搜索日志出發(fā),而由于搜索日志的稀疏性,以及電商商品具有時效性,經(jīng)常根據(jù)季節(jié)變化、時尚趨勢進行變動,導致傳統(tǒng)面向Web搜索的方法在電商領域并不完全適用。
其次,如何評價查詢建議詞的質(zhì)量?高質(zhì)量的查詢建議詞可以引導用戶快速找到所需商品,提高用戶滿意度,促進電商應用的銷售額增長。因此,不同于Web搜索僅考慮網(wǎng)頁點擊率,電商應用還需要考慮與用戶的購物行為相關的影響因素,用于對查詢建議詞的質(zhì)量評估,盡量為用戶提供可促進商品銷售的查詢建議詞,提高商城銷量。
第三,如何保證系統(tǒng)響應的實時性?良好的查詢建議需要用戶每次輸入一個單字后快速返回結果,提供良好的用戶體驗。而面向大規(guī)模數(shù)據(jù)的挖掘算法都需要消耗一定時間才能得到計算結果,因此需要研究合適的離線與在線相結合的計算方法,保障系統(tǒng)的實時響應。
針對上述電商領域的查詢建議存在的問題,本文綜合考慮用戶的搜索行為以及購物行為,運用MapReduce技術對用戶日志進行挖掘,提取查詢詞并計算權重,以此生成檢索詞詞庫;并通過在線計算與離線計算結合的方法,為用戶提供實時查詢建議。實驗結果表明,本文提出的基于日志挖掘的電商查詢建議方法能有效提高查詢建議的準確率,并且具有良好的處理性能。
本文的組織如下:第1節(jié)為引言部分,提出本文需要解決的問題。第2節(jié)介紹查詢建議技術的相關工作。第3節(jié)詳細介紹了本文提出的基于日志的電商查詢建議的系統(tǒng)架構。第4節(jié)為系統(tǒng)原理介紹。第5節(jié)為實驗設計和驗證部分。第6節(jié)對本文進行總結。
國內(nèi)外的學者在優(yōu)化用戶查詢建議方面做了大量的研究和實踐工作。2008年,Google率先推出了搜索關鍵詞建議服務。百度和雅虎也分別在2009年和2010年推出了各自的搜索關鍵詞建議服務。在學術界,查詢建議也是文檔檢索、Web搜索等相關領域內(nèi)活躍的研究主題。
基于查詢建議的目標之一是為非專業(yè)用戶推薦與原始查詢詞相關的專業(yè)查詢詞,早在60年代就有學者提出了利用知識模型來為用戶提供查詢詞擴展的方法。其基本思想是建立查詢詞聚類,根據(jù)查詢詞所映射到的聚類內(nèi)包含的其他詞匯進行查詢擴展[3]。知識模型的構建又可分為人工構建和自動聚類兩類。人工建立詞匯聚類模型是個繁瑣的過程,典型工作是利用WorkNet作為基礎[4]。大部分工作研究根據(jù)待檢索文檔進行自動聚類的方法,如文獻[5]提出了全局和局部分析兩種方法,全局分析指對全部文檔中出現(xiàn)的詞按共同發(fā)生的頻率進行聚類,而局部分析僅利用檢索文檔中的一個子集進行計算,可以獲得更好的計算效率和檢索性能。
另一類工作從用戶的查詢?nèi)罩境霭l(fā)開展研究。用戶查詢?nèi)罩臼潜姸嘤脩羰褂糜涗浀姆e累,從日志中進行挖掘分析,相當于使用大量的用戶相關反饋,可獲取到查詢詞、查詢詞的質(zhì)量以及查詢詞之間的關系。文獻[6]對基于日志的查詢建議方法進行了研究,查詢建議基于用戶的查詢與查詢推薦之間的聯(lián)系的權重,以及用戶對以前查詢推薦的滿意度。文獻[7]提出一種基于用戶日志挖掘的查詢擴展統(tǒng)計模型,將用戶查詢中使用的詞或短語與文檔中出現(xiàn)的相應的詞或短語以條件概率的形式連接,利用貝葉斯公式挑選出文檔中與該查詢關聯(lián)最緊密的詞加入原查詢,以達到擴展優(yōu)化的目的。文獻[8]研究日志中查詢詞的主題聚類方法,查詢詞之間的主題相似度可以通過檢索過程點擊的文檔的相關程度來度量,這種聚類技術可以揭示查詢詞之間潛在的關聯(lián)關系,這種關系在查詢推薦中也得到了應用[9]。文獻[10]通過挖掘用戶日志中查詢詞的關聯(lián)關系來進行查詢建議,擴展詞的選取來自于以往的檢索用詞。文獻[11]提出一個基于查詢?nèi)罩窘⒌牟樵兞鞒虉D系統(tǒng),在查詢流程圖中,每一個頂點代表著一個查詢詞條,每一條邊代表著會話之中的查詢轉換。不同于以上基于用戶查詢歷史的日志挖掘研究,文獻[12]和文獻[13]適當?shù)丶尤肓藢τ脩羝渌袨榈难芯?,對用戶的領域相關的其他操作進行了定義分析,以改善查詢詞的質(zhì)量。
上面所述工作大多集中于傳統(tǒng)文檔檢索和Web網(wǎng)頁檢索領域,而針對電商領域應用需求的研究工作較少。從詞匯模型角度,電商網(wǎng)站的搜索詞和網(wǎng)站內(nèi)的商品相關;從用戶行為角度,電商領域內(nèi)的用戶行為除了搜索行為之外,還有添加購物車、下單等購物相關行為,日志中可供挖掘的信息更多。本文綜合上述兩種方法的優(yōu)點,研究面向電商商品的查詢建議算法,以提高查詢建議的準確率。
由于電商應用的日志量大,查詢建議時用戶反饋要求實時性高,而面向大規(guī)模數(shù)據(jù)的挖掘算法都需要消耗一定時間才能得到計算結果,不能實時對日志數(shù)據(jù)進行分析。因此,本文將查詢建議系統(tǒng)劃分為在線和離線兩個部分,離線部分先對系統(tǒng)之前產(chǎn)生的日志進行分析計算,將計算結果存入檢索詞詞庫,在線部分通過向檢索詞詞庫發(fā)送用戶輸入的檢索詞,獲取相關檢索詞結果,以保證實時性。系統(tǒng)架構如圖1所示。
Figure 1 System architecture圖1 系統(tǒng)架構圖
本文重點討論的是離線部分,離線部分分為HDFS(Hadoop Distributed File System)文件存儲、搜索日志處理、購物行為日志處理和結果統(tǒng)計四部分。
(1)HDFS文件存儲。
由于日志文件規(guī)模較大,因此采用HDFS進行日志文件的存儲。HDFS將讀入的日志文件進行分塊存儲,可提供良好的可擴展性和可靠性。
(2)搜索日志處理。
搜索日志處理模塊主要處理日志中用戶搜索行為產(chǎn)生的關鍵字,將這些關鍵字記錄作為候選的檢索詞。此模塊對應MapReduce中的Map階段,可在Hadoop集群中進行并行計算。
(3)購物行為日志處理。
用戶的購物行為指用戶瀏覽商品、收藏商品、添加購物車以及下訂單等行為,在這部分將對這些用戶行為所對應的關鍵字進行分析,并且給這些關鍵字分類并進行記錄。此模塊也在MapReduce中的Map階段進行并行計算。
(4)結果統(tǒng)計。
結果統(tǒng)計模塊對應MapReduce中的Reduce階段,將搜索日志和購物行為日志處理的結果進行合并統(tǒng)計,最終生成檢索詞詞庫。
在線部分主要是用戶部分或者全部輸入關鍵字的同時,運用ajax異步請求將用戶輸入的關鍵字發(fā)送至服務端,服務端拿到關鍵字通過與檢索詞詞庫的檢索詞匹配,將與關鍵字有包含關系的檢索詞按照權重由高到低的順序返回客戶端,顯示在輸入框的下方。
本系統(tǒng)采用Hadoop平臺的MapReduce并行計算框架對用戶的歷史日志進行分析,如果是用戶的搜索日志,需要從日志中提取搜索詞,統(tǒng)計搜索詞出現(xiàn)的次數(shù),對搜索詞進行打分;如果是用戶的購物行為日志,需要提取日志中四個典型事件,分別是瀏覽、收藏、添加購物車和下單。根據(jù)前人的研究以及商城運營的經(jīng)驗,為這四個事件設置權重。對出現(xiàn)在這四個事件中的商品,以各事件的權重進行統(tǒng)計。
定義1由于算法中需要對關鍵字在日志中以及在用戶行為事件中出現(xiàn)的次數(shù)進行統(tǒng)計、計算,因此檢索詞詞庫中的每一個關鍵字可以定義為一個七元組:
RWT=(K,S,QC,BC,F(xiàn)C,AC,OC)
各屬性含義如下:
(1)K表示檢索詞詞庫中的關鍵字;
(2)S表示該關鍵字最終的得分;
(3)QC表示該關鍵字在搜索日志中出現(xiàn)的次數(shù);
(4)BC表示該關鍵字在瀏覽事件中出現(xiàn)的次數(shù);
(5)FC表示該關鍵字在收藏事件中出現(xiàn)的次數(shù);
(6)AC表示該關鍵字在加入購物車事件中出現(xiàn)的次數(shù);
(7)OC表示該關鍵字在下訂單事件中出現(xiàn)的次數(shù)。
定義2設對于每一個關鍵字q,其在搜索日志中出現(xiàn)的次數(shù)為QC,所有關鍵字在日志文件中出現(xiàn)的次數(shù)為SUMQC,則該關鍵字在搜索日志中的得分為:
對于搜索日志中出現(xiàn)的關鍵字、品牌名、分類名等數(shù)據(jù),我們直接統(tǒng)計其出現(xiàn)的頻率,按照關鍵字(包括品牌、分類等)出現(xiàn)一次記一分的規(guī)則,將日志中出現(xiàn)的關鍵字及其出現(xiàn)的次數(shù)存入表1中。
Table 1 Keywords of event
值得注意的是,輸入的關鍵字中可能存在包含現(xiàn)象,比如:“Adidas”?“Adidas Kanye West”“BURBERRY”?“BURBERRY PRORSUM”“Yeezy”?“Yeezy 350 Spike Black”等,對于這種情況,我們將同時給包含詞和被包含詞各記一分,即如果出現(xiàn)的關鍵字是“Adidas Kanye West”,我們將給關鍵字“Adidas Kanye West”和“Adidas”各加一分;反之,如果出現(xiàn)的關鍵字是“Adidas”,我們將只給“Adidas”加分。
定義3設B、F、A、O分別表示與購物相關的瀏覽行為、收藏行為、添加購物車行為、下訂單行為,其對應的行為權重分別是wB、wF、wA、wO,對于某一種商品關鍵字q,其在某個行為中出現(xiàn)的頻率是fEq(E分別表示B、F、A、O),則根據(jù)數(shù)據(jù)庫及日志中的相關記錄,其在與購物相關的各個行為中的得分為:
SEq=wB*fBq+wF*fFq+wA*fAq+wO*fOq=
對于用戶查看商品詳情的記錄、用戶將商品加入購物車的記錄、用戶收藏商品的記錄以及用戶的購買記錄等數(shù)據(jù),不能直接產(chǎn)生關鍵字與得分,我們將通過一個中間表(如表1所示)進行計算:首先,我們將與購買相關的各個操作定義成購物相關行為,這些行為包括“瀏覽”“收藏”“添加購物車”“下訂單”。然后,通過分析日志以及相關的記錄,設置各個行為的權重(各行為最優(yōu)權重的計算方法將在4.2節(jié)進行說明)。最后,將關鍵字出現(xiàn)的頻率與對應行為的權重相乘,得到關鍵字在某一類行為中的得分,再將關鍵字在各類行為中的得分求和,得到該關鍵字在所有購物相關行為中的總分。
定義4設對于每個關鍵字q,其最終的得分Sq為:
Sq=wL*SLq+wE*SEq
其中,SLq為q在搜索日志中的得分,wL為其對應的權重,SEq為q在購物行為中的得分,wE為其對應的權重。
通過上述計算,對于每一個q最終都會有一個最終的得分Sq與之相對應,隨著用戶在前端關鍵字的鍵入,程序將包含用戶輸入的關鍵字按得分由高到低返回給用戶。
我們使用某電商平臺的日志數(shù)據(jù),包括用戶的關鍵字搜索日志和用戶的購物行為日志。
關鍵字搜索日志如下所示:
[INFO][2017/05/1023:00:41225][net.shop.controller.shop.ProductController.criteria(ProductController.java:220)]member:8222 keywords:inspire
各屬性含義如下:
member:用戶ID
keywords:用戶搜索關鍵字
購物行為日志如下所示:
[INFO][2017/06/11 19:11:67210][net.shop.controller.shop.ProductController.listProductById(ProductController.java:515)]member:3785 product_sn:2017052626261
[INFO][2017/06/11 19:23:32240][net.shop.controller.shop.ProductController.favorite(ProductController.java:952)]member:9723 product_sn:2017031362898
[INFO][2017/06/11 19:42:41352][net.shop.controller.shop.CartController.add(CartController.java:86)]member:5627 product_sn:2017060182659
[INFO][2017/06/11 20:01:31250][net.shop.controller.order.OrderController.create(OrderController.java:443)]member:6245 order_sn:201706117488
各屬性含義如下:
net.shop.controller.shop.ProductController.listProductById:瀏覽商品;
net.shop.controller.shop.ProductController.favorite:收藏商品;
net.shop.controller.shop.CartController.add:添加購物車;
net.shop.controller.order.OrderController.create:創(chuàng)建訂單;
product_sn:商品編號;
order_sn:訂單編號。
MapReduce 是目前比較流行的一個簡化大規(guī)模數(shù)據(jù)處理的并行計算框架,用戶通過該框架提供的一些簡單的編程接口,就能方便地對大規(guī)模數(shù)據(jù)進行處理[14]。結合電商查詢建議的需求,本文提出了一種查詢建議QSLM(Query Suggestion based on Log Mining)算法。
QSLM算法中MapReduce的Map函數(shù)和Reduce函數(shù)的詳細內(nèi)容介紹如下:Map(映射)函數(shù),用來把一組鍵值對映射成一組新的鍵值對,指定并發(fā)的Reduce(歸約)函數(shù),用來合并key值相同的鍵值對。在Map階段是從日志文件中讀取記錄,對于關鍵字搜索記錄,提取日志中的keywords,以keywords作為Map()方法的key,將關鍵字權重作為value;對于用戶行為記錄,提取日志中四類典型購物行為,分別是瀏覽、收藏、添加購物車和下單。根據(jù)前人的研究以及商城運營的經(jīng)驗,為這四類行為設置權重。以相關商品的名稱的分詞作為Map()的key,以各類行為對應的權重作為value。
在Reduce階段,先對Map階段傳過來的鍵值對進行分析,根據(jù)value的值即可得知這個關鍵字所屬的類型,將同類型的所有關鍵字求和,然后再與檢索詞詞庫中的歷史數(shù)據(jù)求和,更新檢索詞詞庫。對檢索詞詞庫進行遍歷,通過對詞庫中的各類型數(shù)據(jù)加權、歸一化,生成關鍵字最后的得分。
QSLM算法的MapReduce處理流程圖2所示。
Figure 2 Process of MapReduce圖2 MapReduce處理流程圖
算法偽代碼描述如下:
算法1QSLM算法
輸入:日志文件;
輸出:檢索詞詞庫。
Map()函數(shù):
1.While (讀取日志中的記錄)
2.Regex.matcher();∥正則匹配記錄
3. If 數(shù)據(jù)是搜索記錄
4.Output〈key,value〉=〈搜索詞,關鍵字權重〉;
5. Else If數(shù)據(jù)是購物行為記錄
6.names[]=segmentation(商品名稱);/*對商品名稱進行分詞*/
7. Fori=0 tonames[].length
8.Output〈key,value〉=〈names[i],購物行為權重〉;
9. End For
10. End If
11.End while
Reduce()函數(shù):
1.While(讀入鍵值對列表〈key,value〉)
2.type=classify(value);/*根據(jù)value判斷類型,包括Q、B、F、A、O五類*/
3.sumtype=sum(keytype);
4.newtype=sum(sumtype,oldtype);/*newtype,oldtype表示某檢索詞type類型的數(shù)據(jù)在檢索詞詞庫中的新統(tǒng)計值與舊統(tǒng)計值*/
5. 將newtype寫入檢索詞詞庫;
6.End while
7.Fori=0 to 檢索詞詞條數(shù)
8.S=Normalization(QC,BC,FC,AC,OC);/*歸一化檢索詞的各個數(shù)據(jù)*/
9.將S寫入檢索詞詞庫最終得分欄;
10.End For
為了驗證QSLM算法是否有效,我們搭建了一套實驗環(huán)境進行實驗驗證。實驗配置為:cnetos 6.5 版本的Linux 操作系統(tǒng),jdk 1.7,Hadoop 版本為 2.3.0。實驗搭建的Hadoop集群為1個master結點和4個worker結點,并開啟了共16個線程。本文所用實驗數(shù)據(jù)來自于某電商平臺從2015年1月1日~2017年6月5日所產(chǎn)生的日志數(shù)據(jù)。
信息檢索領域最廣為人知的評價指標為Precision-Recall(準確率-召回率)方法。召回率(Recall)衡量一個查詢搜索到所有相關文檔的能力,而準確率(Precision)衡量搜索系統(tǒng)排除不相關文檔的能力。
MAP(Mean Average Precison)方法即平均準確率法的簡稱,其定義為求每個相關文檔檢索出后的準確率的平均值(即Average Precision)的算術平均值(Mean)。這里對準確率求了兩次平均,因此稱為Mean Average Precision。MAP是反映系統(tǒng)在全部相關文檔上性能的單值指標。
實驗1QSLM算法驗證。
本實驗以某電商購物網(wǎng)站2017年1月1日~2017年5月31日5個月的日志數(shù)據(jù)為實驗數(shù)據(jù),以2017年6月1日~2017年6月5日5天的日志數(shù)據(jù)為驗證數(shù)據(jù)。通過QSLM算法和基于用戶搜索日志的數(shù)據(jù)挖掘算法對這5天的日志數(shù)據(jù)準確率、召回率和MAP的比較,驗證日志挖掘算法在查詢建議系統(tǒng)中的科學性與實用性。實驗數(shù)據(jù)如圖3所示。
Figure 3 Precision and recall of algorithms圖3 算法準確率與召回率
從實驗的比較中可以清楚地看到,采用QSLM算法的系統(tǒng)的準確率和召回率比起基于搜索日志的日志挖掘算法有大幅提高,采用QSLM算法的MAP達到了0.68,比基于搜索日志的日志挖掘算法的MAP提高了6%。從而驗證了QSLM算法在查詢建議系統(tǒng)的高效性。
實驗2Hadoop性能驗證。
本實驗將通過比較程序在與Hadoop集群節(jié)點配置完全相同的單機環(huán)境和Hadoop集群環(huán)境下,分別在4萬、16萬、32萬、64萬日志數(shù)據(jù)中,生成關鍵字表所用的時間,說明集群環(huán)境的性能優(yōu)勢。實驗結果如圖4所示。
Figure 4 Comparison between single machine and Hadoop圖4 單機與集群性能對比
通過以上實驗,我們發(fā)現(xiàn),當數(shù)據(jù)量不大時,Hadoop集群環(huán)境的運算速度比單機環(huán)境下的運算速度要慢,但是當數(shù)據(jù)量成倍增長時,單機環(huán)境的運行時間幾乎呈指數(shù)增長,而Hadoop集群環(huán)境的運行時間卻沒有太大的變化。實驗結果說明了在大規(guī)模日志數(shù)據(jù)的挖掘中,使用集群并行計算的必要性。
目前,查詢建議廣泛應用于各種搜索引擎。本文針對電商這一特定領域,在總結前人研究的基礎上,提出了一種基于日志挖掘的電商查詢建議方法,綜合考慮用戶的搜索行為以及購物行為,運用MapReduce技術對用戶日志進行挖掘,提取查詢詞并計算權重,以此生成檢索詞詞庫;并通過在線計算與離線計算結合的方法,為用戶提供實時查詢建議。實驗結果表明,本文提出的基于日志挖掘的電商查詢建議算法能有效提高查詢建議的準確率,并且具有良好的處理性能。當然本算法還有許多需要改進的地方,后續(xù)我們將進一步考慮商品庫存、商品時效性等因素,優(yōu)化檢索詞庫的檢索詞提取以及評分機制。
[1] Ooi J,Ma X,Qin H,et al.A survey of query expansion,query suggestion and query refinement techniques[C]∥Proc of International Conference on Software Engineering and Computer Systems,2015:112-117.
[2] China Internet Network Information Center. The 39th 《China Statistical Report on Internet Development》[EB/OL].[2017-01-22].http:∥www.cnnic.net.cn.(in Chinese)
[3] Peat H J,Willett P.The limitations of term co-occurrence data for query expansion in document retrieval systems[J].Journal of the Association for Information Science & Technology,1991,42(5):378-383.
[4] Fox E A.Lexical relations:Enhancing effectiveness of information retrieval systems[J].ACM Sigir Forum,1980,15(3):5-36.
[5] Vechtomova O, Robertson S, Jones S. Query expansion with long-span collocates[J].Information Retrieval,2003,6(2):251-273.
[6] Baeza-Yates R,Hurtado C,Mendoza M.Query recommendation using query logs in search engines[C]∥Proc of EDBT 2004,2004:588-596.
[7] Cui Hang, Wen Ji-rong, Li Min-qiang, et al.A statistical query expansion model based on query logs[J].Journal of Software,2003,14(9):1593-1599.(in Chinese)
[8] Wen J,Nie J Y,Zhang H.Query clustering using user logs[J].ACM Transactions on Information Systems,2002,20(1):59-81.
[9] Zhang Z,Nasraoui O.Mining search engine query logs for query recommendation[C]∥Proc of International Conference on World Wide Web,2006:1039-1040.
[10] Billerbeck B,Scholer F,Williams H E,et al.Query expansion using associated queries[C]∥Proc of International Conference on Information & Knowledge Management,2003:2-9.
[11] Hasan M A,Parikh N,Singh G,et al.Query suggestion for E-commerce sites[C]∥Proc of WSDM 2001,2011:765-774.
[12] Yang Q, Ling C X,Gao J.Mining web logs for actionable knowledge[M]∥Intelligent Technologies for Information Analysis.Berlin:Springer,2004:169-191.
[13] Chen Z, Yamamoto T, Tanaka K.Query suggestion for struggling search by struggling flow graph[C]∥Proc of International Conference on Web Intelligence,2017:224-231.
[14] Dean J,Ghemawat S.MapReduce:Simplified data processing on large clusters[J].Communicatons of the ACM,2008,50(1):107-113.
附中文參考文獻:
[2] 中國互聯(lián)網(wǎng)絡信息中心.第39次《中國互聯(lián)網(wǎng)絡發(fā)展狀況統(tǒng)計報告》[EB/OL].[2017-01-22].http:∥www.cnnic.net.cn.
[7] 崔航,文繼榮,李敏強.基于用戶日志的查詢擴展統(tǒng)計模型[J].軟件學報,2003,14(9):1593-1599.