讓天下沒有難用的搜尋:阿里搜尋如何成長為貼心“暖男”?
阿里妹導讀:第十個雙11已圓滿結束,但是技術的探索永不止步。阿里技術推出《十年牧碼記》系列,邀請參與歷年雙11大戰的核心技術大牛,一起回顧阿里技術的變遷。
近十年,機器智慧在越來越多的領域走進和改變著我們的生活。在網際網路領域,機器智慧則是得到了更普遍和廣泛的應用。作為電商平臺的基石,商品搜尋團隊一直在打造適合電商平臺的機器智慧體系。而每年雙11,則是驗證智慧化程式的試金石。今天,阿里資深演算法專家元涵帶你穿越時空,感受雙11場景下搜尋智慧化的十年演進道路。
阿里搜尋技術體系演進至今天,基本形成了由offline、nearline、online三層體系,分工協作,保證電商平臺上,既能適應日常平穩流量下穩定有效的個性化搜尋及推薦,也能夠去滿足電商平臺對促銷活動的技術支援,實現在短時高併發流量下的平臺收益最大化。
可以看到,十年雙11的考驗後,搜尋智慧化體系逐漸打造成型,已經成為電商平臺穩定健康發展的核動力,主要分為四個階段:自主研發的流式計算引擎Pora初露鋒芒;雙鏈路實時體系大放異彩;“深度學習+強化學習”初步探路;全面進入深度學習時代。下面我們就來一起看一下。
四大演進階段:業務、演算法、系統同步發展
階段一:初露鋒芒——自主研發的流式計算引擎Pora
技術的演進是伴隨解決實際業務問題和痛點發展和進化的。2014年雙11,通過BI團隊針對往年雙11的資料分析,發現即將售罄的商品仍然獲得了大量流量,剩餘庫存無法支撐短時間內的大使用者量。主售款(熱銷sku)賣完的商品獲得了流量,使用者無法買到商品熱銷的sku,轉化率低;與之相對,一些在雙11當天才突然展露出來的熱銷商品卻因為歷史成交一般沒有得到足夠的流量。
針對以上問題,通過搜尋技術團隊自主研發的流式計算引擎Pora,收集預熱期和雙11當天全網使用者的所有點選、加購、成交行為日誌,按商品維度累計相關行為數量,並實時關聯查詢商品庫存資訊,提供給演算法外掛進行實時售罄率和實時轉化率的計算分析,並將計算結果實時更新同步給搜尋和推薦引擎,影響排序結果。第一次在雙11大促場景下實現了大規模的實時計算。演算法效果上,也第一次讓大家感受到了實時計算的威力,PC端和移動端金額也得到顯著提升。
階段二:大放異彩——雙鏈路實時體系
2014年雙11,實時技術在大促場景上,實現了商品和使用者的特徵實時,表現不俗。
2015年搜尋技術和演算法團隊繼續推動線上計算的技術升級,基本確立了構築基於實時計算體系的【線上學習+決策】搜尋智慧化的演進路線。
早先的搜尋學習能力,是基於批處理的離線機器學習。在每次迭代計算過程中,需要把全部的訓練資料載入到記憶體中計算。雖然有分散式大規模的機器學習平臺,在某種程度上批處理方法對訓練樣本的數量還是有限制的。線上學習不需要快取所有資料,以流式的處理方式可以處理任意數量的樣本,做到資料的實時消費。
接下來,我們要明確兩個問題:為什麼需要線上學習呢?以及為什麼實現秒級的模型更新?
在批量學習中,一般會假設樣本獨立服從一個未知的分佈,但如果分佈變化,模型效果會明顯降低。而在實際業務中,很多情況下,一個模型生效後,樣本的分佈會發生大幅變化,因此學到的模型並不能很好地匹配線上資料。實時模型,能通過不斷地擬合最近的線上資料,解決這一問題,因此效果會較離線模型有較大提升。那麼為什麼實現秒級分鐘級的模型更新?在雙11這種成交爆發力強、變化劇烈的場景,秒級實時模型相比小時級實時模型時效性的優勢會更加明顯。根據2015年雙11實時成交額情況,前面1小時已經完成了大概總成交的1/3,小時模型就無法很好地捕獲這段時間裡面的變化。
基於此,搜尋技術團隊基於Pora開發了基於parameter server的線上學習框架,如下圖所示,實現了線上訓練,開發了基於pointwise的實時轉化率預估模型,以及基於pairwise的線上矩陣分解模型。並通過swift輸送模型到引擎,結合實時特徵,實現了特徵和模型雙實時的預測能力。
線上學習框架
但是,無論是離線訓練還是線上學習,核心能力是儘可能提高針對單一問題的演算法方案的準確度,卻忽視了人機互動的時間性和系統性,從而很難對變幻莫測的使用者行為以及瞬息萬變的外部環境進行完整的建模。典型問題是在個性化搜尋系統中容易出現反覆給消費者展現已經看過的商品。
如何避免系統過度個性化,通過高效的探索來增加結果的豐富性?我們開始探索機器智慧技術的另一方向——強化學習,運用強化學習技術來實現決策引擎。我們可以把系統和使用者的互動過程當成是在時間維度上的【state,action,reward】序列,決策引擎的目標就是最優化這個過程。
線上決策方面,我們首次嘗試了運用MAB和zero-order優化技術實現多個排序因子的最優融合策略,取代以前依靠離線Learningto rank學到的排序融合引數。其結果是顯著的,在雙11當天我們也觀察到,通過實時策略尋優,一天中不同時間段的最優策略是不同的,這相比全天使用離線學習得到的一套固定排序權重是一個大的進步。
2015年雙11雙鏈路實時計算體系如下圖所示:
2015年雙11的實時計算體系
階段三:初步探路——“深度學習+強化學習”
2015年雙11,線上學習被證明效果顯著,然而回顧當天觀察到的實時效果,也暴露出一些問題。
問題一:線上學習模型方面,該模型過度依賴從0點開始的累積統計訊號,導致後場大部分熱銷商品都無法在累積統計訊號得到有效的差異化表示,模型缺少針對資料的自適應能力。
問題二:線上決策方面。2015年雙11,巨集觀實時體系中的MAB( Multi-ArmedBandit)實時策略尋優發揮了重要作用,通過演算法工程師豐富經驗制定的離散排序策略集合,MAB能在雙11當天實時選擇出最優策略進行投放;然而,同時暴露出MAB基於離散策略空間尋優的一些問題,離散策略空間仍然是拍腦袋的智慧。同時為了保證MAB策略尋優的統計穩定性,幾十分鐘的迭代週期仍然無法匹配雙11當天流量變化的脈搏。
針對第一個問題,我們在2016年雙11中也進行了優化和改進。對於從0點的累積統計訊號到後場飽和以及統計值離散化缺少合理的抓手的問題,我們參考Facebook在AD-KDD的工作,在此基礎上,結合線上學習,我們研發了Streaming FTRL stacking on DeltaGBDT模型,如下圖所示。
Streaming FTRL stacking on DeltaGBDT模型
分時段GBDT模型會持續為實時樣本產出其在雙11當天不同時段的有效特徵,並由onlineFTRL去學習這些時效性特徵的相關性。
對於線上決策方面的問題,我們進行了策略空間的最優化探索,分別嘗試了引入delay reward的強化學習技術,即在搜尋中採用強化學習(ReinforcementLearning)方法對商品排序進行實時調控優化。我們把搜尋引擎看作智慧體(Agent)、把使用者看做環境(Environment),則商品的搜尋問題可以被視為典型的順序決策問題(Sequential Decision-making Problem)。我們的目標就是要實現用平臺長期累積收益的最大化。
系統方面,2016年雙11我們的實時計算引擎從istream時代平穩升級到到 Blink/Flink 時代,實現24小時不間斷無延遲運轉,機器學習任務從幾個擴大到上百個job。為演算法實現大規模線上深度學習和強化學習等前沿技術打下了堅實的基礎。
階段四:全面進入——深度學習時代
由於線上深度學習需要強大的計算資源來支援,2017年系統上我們重構了流式計算平臺、機器學習平臺和支援CPU/GPU的異構線上服務平臺,能夠支援更大規模的流式資料計算,超大規模深度模型線上學習和線上預估。
依託強大的計算能力,實現了深度學習在搜尋的全面落地,包括語義搜尋,深度使用者興趣感知,商品多模表示學習,線上深度機制模型,多場景協同智慧決等技術創新:
a) 深度使用者感知模型:搜尋或推薦中個性化的重點是使用者的理解與表達,基於淘寶的使用者畫像靜態特徵和使用者行為動態特徵,我們提出基於multi-modals learning、multi-task representation learning以及LSTM的相關技術,從海量使用者行為日誌中直接學習使用者的通用表達,該學習方法善於“總結經驗”、“觸類旁通”,使得到的使用者表達更基礎且更全面,能夠直接用於使用者行為識別、偏好預估、個性化召回、個性化排序等任務,在搜尋、推薦和廣告等個性化業務中有廣泛的應用場景。(相關成果的論文已被KDD 2018 錄用)
b)大規模商品多模表示學習:淘寶商品有文字、影像、標籤、id 、品牌、類目、店鋪,統計特徵等多模態資訊,這些特徵彼此有一定程度的冗餘和互補,我們利用多模學習將多維度特徵融合在一起學習一個統一的商品向量,並通過attention機制實現不同特徵維度在不同場景下的差異,比如女裝下圖片特徵比較重要,3C下價格,銷量比較重要等。
c)線上深度機制模型:由於不同使用者和不同場景的優化目標不一樣,我們把使用者狀態,場景相關特徵加入到了機制模型中,實現了千人千面的排序機制模型。同時由於各種基礎實時日誌的qps和延遲都不太一樣,為了保證線上學習的穩定性,我們構建了實時樣本pool來維護一個穩定的樣本集合供線上學習使用。
d) 全域性排序:傳統的排序模型只對單個文件打分,然後按照分數從高到底排序。這樣方法無法考慮到商品之間相互的影響;傳統的針對單個商品ctr、cvr都基於這樣一個假設:商品的ctr、cvr不會受到同時展示出來的其他商品(我們稱為展示context)的影響。而實際上一個商品的展示context可以影響到使用者的點選或者購買決策:假如同一個商品周邊的商品都和它比較類似,而且價格都比它便宜,那麼使用者買它的概率不會高;反之如果周邊差不多的商品都比它貴,那麼使用者買它的概率就會大增。而全域性排序就要解決這個問題,考慮商品之間的相互影響,實現整頁效率的最大化。(相關成果的論文已被IJCAI2018 錄用)
e) 多場景協同智慧決策:搜尋多個不同的產品都是依託個性化來實現GMV最大化,導致的問題是不同產品的搜尋結果趨同。而導致這個問題的根本原因是不同場景的演算法各自為戰,缺乏合作和關聯。今年做的一個重要工作是利用多智慧體協同學習技術,實現了搜尋多個異構場景間的環境感知、場景通訊、單獨決策和聯合學習,實現聯合收益最大化,而不是此消彼長(相關成果的論文已被 www 2018錄用)。
驅動搜尋智慧化體系的演進的三點
我們再回過頭來看,是什麼驅動了搜尋智慧化體系的演進?
目前,各大網際網路公司的主流技術路線主要是運用機器學習技術來提升搜尋/推薦平臺的流量投放效率,隨著計算力和資料的規模增長,大家都在持續地優化和深入。是什麼驅動我們推動搜尋的智慧化體系從離線建模、線上預測向線上學習和實時決策方向演進呢?概括來說,主要有以下三點。
首先,眾所周知,淘寶搜尋具有很強的動態性,寶貝的迴圈擱置,新賣家加入,賣家新商品的推出,價格的調整,標題的更新,舊商品的下架,換季商品的促銷,寶貝圖片的更新,銷量的變化,賣家等級的提升等等,都需要搜尋引擎在第一時間捕捉到這些變化,並在最終的排序環節,把這些變化及時地融入匹配和排序,帶來結果的動態調整。
其次,從2013年起,淘寶搜尋就進入千人千面的個性化時代,搜尋框背後的查詢邏輯,已經從基於原始Query演變為【Query+使用者上下文+地域+時間】,搜尋不僅僅是一個簡單根據輸入而返回內容的不聰明的“機器”,而是一個能夠自動理解、甚至提前猜測使用者意圖(比如使用者瀏覽了一些女士牛仔褲商品,然後進入搜尋輸入查詢詞“襯衫”,系統分析使用者當前的意圖是找女性相關的商品,所以會展現更多的女士襯衫,而不是男生襯衫),並能將這種意圖準確地體現在返回結果中的聰明系統,這個系統在面對不同的使用者輸入相同的查詢詞時,能夠根據使用者的差異,展現使用者最希望看到的結果。變化是時刻發生的,商品在變化,使用者個體在變化,群體、環境在變化。在搜尋的個性化體系中合理地捕捉變化,正是實時個性化要去解決的課題。
最後,電商平臺也完成了從PC時代到移動時代的轉變,隨著移動時代的到來,人機互動的便捷、碎片化使用的普遍性、業務切換的序列化,要求我們的系統能夠對變化莫測的使用者行為以及瞬息萬變的外部環境進行完整的建模。基於監督學習時代的搜尋和推薦,缺少有效的探索能力,系統傾向於給消費者推送曾經發生過行為的商品或店鋪。
真正的智慧化搜尋和推薦,需要作為投放引擎的agent有決策能力,這個決策不是基於單一節點的直接收益來確定,而是當作一個人機互動的過程,消費者與平臺的互動看成是一個馬爾可夫決策過程,運用強化學習框架,建立一個消費者與系統互動的迴路系統,而系統的決策是建立在最大化過程收益基礎上。
未來展望——讓淘寶搜尋擁有智慧化的體驗
經過這麼十年雙11大促的技術錘鍊後,圍繞線上AI技術的智慧框架初具規模,基本形成了線上學習加智慧決策的智慧搜尋系統,為電商平臺實現消費者、賣家、平臺三方利益最大化奠定了堅實的基礎。這套具備學習加決策能力的智慧系統也讓搜尋從一個簡單的找商品的機器,慢慢變成一個會學習會成長,懂使用者,體貼使用者的“人”。
但在這個過程中,搜尋排序學習到的知識更多都是通過已有的商品標籤資料和使用者行為資料來獲取的,還缺少對商品和使用者更深層次的認知,還無法完全理解使用者的多元意圖表達的真實需求。
比如,使用者搜尋了“性感連衣裙”,可能是想找“去參加晚場party的低胸晚裝裙”,也可能是想找“去海邊度假的露肩沙灘裙”;使用者收藏了“登山鞋”和“柺杖”,可能有“登山裝備”的需求,需要發現更多的和登山裝備相關的其它品類商品。一個有孩子的爸爸,在暑假剛開始時,挑選“轉換接頭”,檢視“大英博物館門票”,可能是想帶著家人一起“暑期英國親子游”,需要發現更多相關的其它品類商品。
究其原因,目前機器智慧技術特別是以深度學習為代表的模型,在現實應用中快速發展,最主要受益於海量大資料以及大規模計算能力,通過對物理世界的數字化抽象和程式化學習,使得機器智慧具備很強的限定知識的獲取能力,而很難獲得資料之外的知識,就更不用說知識的類比、遷移和推理了。
而機器的認知智慧,比如自主學習和發現,甚至創造能力才是人工智慧的更高境界。當然通用的機器智慧還有很多工作要做,在這個過程中,怎麼樣首先結合人類知識和機器智慧做到初步的認知智慧,讓淘寶搜尋擁有智慧化的體驗是未來值得探索的方向。
我們有理由相信,隨著智慧技術的進一步升級,這個“人”會越來越聰明,實現機器智慧,認知智慧的終極目標。
你可能還喜歡
點選下方圖片即可閱讀
關注「阿里技術」
把握前沿技術脈搏
相關文章
- 貪心+搜尋
- 最佳路徑搜尋(二):啟發式搜尋(代價一致搜尋(Dijkstra search),貪心搜尋,A*搜尋)
- 啟發式搜尋的方式(深度優先,廣度優先)和 搜尋方法(Dijkstra‘s演算法,代價一致搜尋,貪心搜尋 ,A星搜尋)演算法
- 雲搜尋服務在APP搜尋場景的應用APP
- 海量資料搜尋---搜尋引擎
- Elasticsearch 為了搜尋Elasticsearch
- 搜尋
- 搜尋引擎-03-搜尋引擎原理
- 恕我直言,你可能連 GitHub 搜尋都不會用 - 如何精準搜尋的神仙技巧Github
- Elasticsearch(ES)的高階搜尋(DSL搜尋)(上篇)Elasticsearch
- Elasticsearch(ES)的高階搜尋(DSL搜尋)(下篇)Elasticsearch
- 點選搜尋框清空搜尋提示文字
- 搜尋引擎es-分詞與搜尋分詞
- 搜尋的未來是精品搜尋 | a16z
- 360搜尋站長平臺
- 「Golang成長之路」迷宮的廣度優先搜尋Golang
- Nebula 基於 ElasticSearch 的全文搜尋引擎的文字搜尋Elasticsearch
- win10搜尋框太長如何縮小_win10縮小搜尋框的步驟Win10
- 直播系統程式碼,常用搜尋中搜尋歷史,搜尋推薦功能
- 搜尋技巧
- vim搜尋
- 搜尋策略
- 搜尋功能
- 用 google 作為你的預設搜尋引擎Go
- 如何解決使用mac聚焦搜尋無法搜尋軟體的情況Mac
- 20240713總結(搜尋專題,但是不想搜尋)
- 阿里雲葛岱斌:讓天下沒有難做的安全運維阿里運維
- Mac上神奇的內建搜尋引擎——Spotlight(聚焦搜尋)Mac
- NLP技術如何為搜尋引擎賦能
- 剛剛!ChatGPT正式成為AI搜尋,免費可用ChatGPTAI
- WIN10的搜尋無效怎麼辦 win10系統搜尋沒有效果如何解決Win10
- 谷歌搜尋用上BERT,10%搜尋結果將改善谷歌
- 直播開發app,實時搜尋、搜尋引擎框APP
- 使用Google百度等搜尋引擎的常用搜尋技巧Go
- MacOS的Safari搜尋欄無法搜尋怎麼解決?Mac
- MySQL用LIKE特殊字元搜尋MySql字元
- Win10系統中搜尋框搜尋不到本地應用和檔案如何解決Win10
- 自然搜尋排名該如何提高?