0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

解密游戲推薦系統(tǒng)的建設(shè)之路

OSC開源社區(qū) ? 來源:OSC開源社區(qū) ? 2023-03-06 09:59 ? 次閱讀

本文從零開始介紹了游戲推薦項(xiàng)目的發(fā)展歷程,闡述了大型項(xiàng)目建設(shè)中遇到的業(yè)務(wù)與架構(gòu)問題以及開發(fā)工程師們的解決方案,描繪了游戲推薦項(xiàng)目的特點(diǎn)以及業(yè)務(wù)發(fā)展方向,有著較好的參考與借鑒意義。

一、游戲推薦的背景與意義

信息獲取的角度來看,搜索和推薦是用戶獲取信息的兩種主要手段,也是有效幫助產(chǎn)品變現(xiàn)的兩種方式,搜索是一個非常主動的行為,并且用戶的需求十分明確,在搜索引擎提供的結(jié)果里,用戶也能通過瀏覽和點(diǎn)擊來明確的判斷是否滿足了用戶需求。

然而,推薦系統(tǒng)接受信息是被動的,需求也都是模糊而不明確的。推薦系統(tǒng)的作用就是建立更加有效率的連接,更有效率地連接用戶與內(nèi)容和服務(wù),節(jié)約大量的時間和成本。以此背景,游戲推薦系統(tǒng)由此誕生。

98e527e2-bb81-11ed-bfe3-dac502259ad0.jpg

游戲推薦系統(tǒng)從設(shè)計之初就作為游戲分發(fā)的平臺,向公司內(nèi)所有主要流量入口(游戲中心、應(yīng)用商店、瀏覽器、jovi等)分發(fā)游戲,系統(tǒng)通過各種推薦算法及推薦策略,為用戶推薦下載付費(fèi)意愿較高且兼顧商業(yè)價值的游戲,從而為公司帶來收入。發(fā)展至今天,該系統(tǒng)還具備類游戲內(nèi)容與素材的推薦功能。

二、游戲推薦的初期模型

游戲推薦的目的是推出用戶想要且兼顧商業(yè)價值的游戲,以此來提高業(yè)務(wù)的收入指標(biāo)。此處的商業(yè)價值是由運(yùn)營側(cè)通過策略規(guī)則去把控的,而用戶意向游戲則是通過算法排序得到的,算法排序所需要的特征數(shù)據(jù),以及推薦效果的反饋數(shù)據(jù)則由埋點(diǎn)信息上報以供計算分析。

因此我們的模型可以分成四大塊:

運(yùn)營推薦規(guī)則配置

算法模型訓(xùn)練

推薦策略生效

數(shù)據(jù)埋點(diǎn)上報

990f166a-bb81-11ed-bfe3-dac502259ad0.jpg

模塊間的交互如下:在策略生效前,運(yùn)營會先在配置中心生成對應(yīng)的配置規(guī)則,這些規(guī)則會以緩存的形式存儲以供推薦高并接口調(diào)用。當(dāng)用戶訪問app應(yīng)用某些特定頁面時,其后臺會帶著對應(yīng)的場景信息來請求游戲推薦后臺,推薦后臺根據(jù)場景信息映射相關(guān)配置(召回,標(biāo)簽,過期,算法等..........)調(diào)用算法服務(wù)并進(jìn)行資源排序,最終將推薦的結(jié)果反饋給app應(yīng)用。

app應(yīng)用在展示推薦頁面的同時,也將用戶相應(yīng)的行為數(shù)據(jù)以及推薦數(shù)據(jù)的相關(guān)埋點(diǎn)進(jìn)行上報。

三、業(yè)務(wù)增長與架構(gòu)演進(jìn)

隨著接入系統(tǒng)帶來的正向收益的提升,越來越多的業(yè)務(wù)選擇接入游戲推薦系統(tǒng),這使得我們支持的功能日益豐富。

目前游戲推薦覆蓋的場景有分類、專題、榜單、首頁、搜索等;包含的策略類型有干預(yù)、打散、資源配比、保量;支持的推薦類型更是豐富:聯(lián)運(yùn)游戲、小游戲、內(nèi)容素材、推薦理由。

這些豐富的使用場景使得業(yè)務(wù)的復(fù)雜度成本增長,令我們在性能,擴(kuò)展性,可用性上面臨著新的挑戰(zhàn),也推動著我們架構(gòu)變革。

3.1 熵增環(huán)境下的通用組合策略

在0 到 1 的過程中,游戲推薦聚焦于提高分發(fā)量,這時候考慮得更多的是怎么把游戲推出去,在代碼實(shí)現(xiàn)上使用分層架構(gòu)來劃分執(zhí)行的業(yè)務(wù)。

但是在1 到 2 的過程中, 我們游戲推薦不僅僅推薦游戲,也推薦內(nèi)容和素材;同時在策略調(diào)用上也更加靈活,不同場景其調(diào)用的策略是不同的,執(zhí)行順序也是不同的;更重要的是加入了很多用戶個性化業(yè)務(wù)與動態(tài)規(guī)則,這些都使得現(xiàn)有業(yè)務(wù)代碼急劇膨脹,擴(kuò)展起來捉襟見肘,無從下手。因此我們急需一個高復(fù)用,易擴(kuò)展,低代碼的策略框架去解決這些問題。

99323974-bb81-11ed-bfe3-dac502259ad0.jpg

如圖所示,通用組合策略負(fù)責(zé)流轉(zhuǎn)的角色有兩個acceptor和executor,通訊媒介是推薦上下文context。負(fù)責(zé)執(zhí)行邏輯的角色有三個matcher,listener和process,它們都有多個不同邏輯的實(shí)現(xiàn)類。當(dāng)請求游戲推薦系統(tǒng)時,acceptor會先從配置中動態(tài)查詢策略模板進(jìn)行匹配,接著listener組件會執(zhí)行相應(yīng)的預(yù)處理邏輯。處理后acceptor通過上下文context將任務(wù)流轉(zhuǎn)給executor處理器。executor再根據(jù)配置,將process根據(jù)前置條件進(jìn)行篩選并排列組合,最后埋點(diǎn)返回。

經(jīng)過這套通用的策略,我們在實(shí)現(xiàn)一般業(yè)務(wù)的時候,只要擴(kuò)展具體matcher和process,并在配置中心將場景和處理優(yōu)先級綁定起來,就能完成大部分的場景開發(fā),這樣研發(fā)者可以更聚焦于某個邏輯流程的開發(fā),而不用疲于梳理代碼,并進(jìn)行擴(kuò)展設(shè)計。

3.2 多級緩存與近實(shí)時策略

游戲推薦系統(tǒng)服務(wù)于手機(jī)游戲用戶,處于整個系統(tǒng)鏈路的下游,峰值流量在3W TPS左右 ,是個讀遠(yuǎn)多于寫的系統(tǒng)?!白x”流量來自于用戶在各種推薦場景,列表、搜索、下載錢下載后、榜單等,寫數(shù)據(jù)主要來源于運(yùn)營相關(guān)策略的變更,所以我們面臨的一個重大挑戰(zhàn)就是如何在保證可用性的前提下應(yīng)對高頻的讀請求。

為了保證系統(tǒng)的讀性能,我們采用了redis + 本地緩存的設(shè)計。配置更新后先寫mysql,寫成功后再寫redis。本地緩存定時失效,使用懶加載的方式從redis中讀取相關(guān)數(shù)據(jù)。這種設(shè)計能保證最終一致性,軟狀態(tài)時服務(wù)集群數(shù)據(jù)存在短暫不一致的情況,早期對業(yè)務(wù)影響不大,可以認(rèn)為是一個逐步放量的過程。

995c013c-bb81-11ed-bfe3-dac502259ad0.jpg

早期原先部署節(jié)點(diǎn)較少,整個系統(tǒng)達(dá)到最終一致性的時間較短,但隨著節(jié)點(diǎn)增加到數(shù)百臺,這個時間就變得不是那么和諧了。

同時隨著業(yè)務(wù)復(fù)雜度的增加,常常是多個配置策略決定這一個推薦結(jié)果,此時本地緩存的狀態(tài)極大影響了測試和點(diǎn)檢的便利,如果配置更改不能做到立馬更新本地緩存,那就要等待漫長的一段時間才能開始驗(yàn)證邏輯。因此,我們對緩存結(jié)構(gòu)做出了如下的調(diào)整:

99748fc2-bb81-11ed-bfe3-dac502259ad0.jpg

與先前不同的是,我們加入消息隊(duì)列并通過配置版本號的比對來實(shí)現(xiàn)策略的實(shí)時更新同步,取得了很好的效果。

3.3 高并服務(wù)的垃圾回收處理

任何一個java服務(wù)都逃離不了FGC的魔咒,高并服務(wù)更是如此。很多服務(wù)每天兩位數(shù)的FGC更是家常便飯,顯然這對業(yè)務(wù)的穩(wěn)定性和服務(wù)性能影響是巨大的。游戲推薦這邊通過不斷實(shí)踐總結(jié)了一套較為通用的方法很好地解決了這個問題:

999dc766-bb81-11ed-bfe3-dac502259ad0.png

可以看到起初jvm配置較為常規(guī):1G的年輕代,2G的老年代以及一些其他常見的多線程回收的配置,其結(jié)果就是每天10次的FGC,YGC單次耗時在100ms,F(xiàn)GC耗時在350 - 400ms。我們知道線上接口容忍的范圍一般是200ms以內(nèi),不超過300ms,這樣顯然是不達(dá)標(biāo)的。

通過分析,我們發(fā)現(xiàn)高并服務(wù)的高頻FGC來源于這幾個方面:

大量的本地緩存(堆內(nèi))占據(jù)了老年代的空間,大大增加了老年代疊滿的頻率。

高并請求導(dǎo)致了對象的急速生成,年輕代空間不足以容納這劇增的對象,導(dǎo)致其未達(dá)到存活閾值(15次)就晉升至老年代。

引入的監(jiān)控組件為了性能,常常延遲 1 - 2 min再將數(shù)據(jù)上報服務(wù)端,導(dǎo)致這部分?jǐn)?shù)據(jù)也無法在年輕代被回收。

當(dāng)然這還不是問題的全部,F(xiàn)GC還有個致命問題就是stop the world,這會導(dǎo)致業(yè)務(wù)長時間無法響應(yīng),造成經(jīng)濟(jì)損失。反過來,就算FGC頻繁,stop the world 只有1ms,也是不會對業(yè)務(wù)造成影響的,因此不能單單以FGC的頻率來判斷jvm服務(wù)的gc性能的好壞。經(jīng)過上面的探討,我們在實(shí)踐中得到了如下的解決方案:

不常變化的緩存(小時級別)移到堆外,以此減少老年代疊滿的基礎(chǔ)閾值。

變化不那么頻繁的緩存(分鐘級別)更新的時候進(jìn)行值對比,如果值一樣則不更新,以此減少老年代的堆積。

使用G1回收器:-XX:+UseG1GC

-XX:MaxGCPauseMillis=200

-XX:InitiatingHeapOccupancyPercent=25

-XX:MaxNewSize=3072M -Xms4608M -Xmx4608M -XX:MetaspaceSize=512M

-XX:MaxMetaspaceSize=512M

99df03ac-bb81-11ed-bfe3-dac502259ad0.png

其效果如上所示,調(diào)整后各項(xiàng)指標(biāo)都有很大的進(jìn)步:由于年輕代中的復(fù)制算法使其垃圾清理速度較快,所以調(diào)大其容量使對象盡量在其中回收,同時設(shè)置每次清理的時間,使得mix gc控制在200ms以內(nèi)。

3.4 限流降級與兜底策略

為了保證業(yè)務(wù)的可用性,大部分業(yè)務(wù)都會引入hystrix, sentinel, resilience4j 這類熔斷限流組件, 但這些組件也不能解決全部的問題。

對于游戲推薦來說,一臺節(jié)點(diǎn)往往承載著不同的業(yè)務(wù)推薦,有些業(yè)務(wù)十分核心,有些不是那么重要,限流降級的時候不是簡單的哪個服務(wù)限流多少問題,而是在權(quán)衡利弊的情況下,將有限的資源向哪些業(yè)務(wù)傾斜的問題,對此我們在分層限流上下足了功夫。

9a349cf4-bb81-11ed-bfe3-dac502259ad0.jpg

同時對于個性化業(yè)務(wù)來說,僅僅返回通用的兜底會使推薦同質(zhì)化,因此我們的策略是將用戶的歷史數(shù)據(jù)存儲下來,并在下次兜底的時候作為推薦列表進(jìn)行返回。

9a525abe-bb81-11ed-bfe3-dac502259ad0.jpg

四、精細(xì)化運(yùn)營模式的探索

在經(jīng)歷過了0 到1 的開疆拓土 與 1 到 2 的高速增長后,游戲的推薦架構(gòu)已經(jīng)趨于穩(wěn)定。這時候我們更加關(guān)注效能的提高與成本的下降,因此我們開始著手于系統(tǒng)運(yùn)營的精細(xì)化設(shè)計,這對推薦系統(tǒng)的良性發(fā)展是意義重大的。

精細(xì)化運(yùn)營不僅能提高尾量游戲的收入,提高運(yùn)營人員的工作效率,還能實(shí)時快速反饋算法在線效果并立馬做出調(diào)整,做到一個業(yè)務(wù)上的閉環(huán)。首先就不得不提到游戲推薦系統(tǒng)的分層正交實(shí)驗(yàn)平臺,這是我們做精細(xì)化運(yùn)營的基礎(chǔ)。

4.1 多層 hash 正交實(shí)驗(yàn)平臺

游戲推薦的關(guān)鍵就一個"準(zhǔn)"字,這就需要通過精細(xì)化策略迭代來提升效率和準(zhǔn)確度,從而不斷擴(kuò)大規(guī)模優(yōu)勢,實(shí)現(xiàn)正向循環(huán)。然而策略的改變并不是通過“頭腦風(fēng)暴”空想的,而是一種建立在數(shù)據(jù)反饋上的機(jī)制,以帶來預(yù)期內(nèi)的正向變化。這就需要我們分隔對照組來做A/Btest。

一般線上業(yè)務(wù)常見的A/B test是通過物理方式對流量進(jìn)行隔離,這種方法常見于H5頁面的分流實(shí)驗(yàn),但面對復(fù)雜業(yè)務(wù)時卻存在著部署較慢,埋點(diǎn)解析困難等問題,其典型的架構(gòu)方式如下:

9a741424-bb81-11ed-bfe3-dac502259ad0.jpg

對于游戲推薦來說,其完成一次推薦請求的流程比較復(fù)雜,涉及到多組策略,為了保證線上流量的效率與互斥,就不能采用簡單的物理分配流量的方式。

因此在業(yè)務(wù)層我們建立了一套多層hash正交實(shí)驗(yàn)規(guī)則來滿足我們A/B test的要求。

與物理隔離流量,部署多套環(huán)境的方式不同,分層模型在分流算法中引入層級編號因子(A)來解決流量饑餓和流量正交問題。每一實(shí)驗(yàn)層可以劃分為多個實(shí)驗(yàn)田,當(dāng)流量經(jīng)過每一層實(shí)驗(yàn)時,會先經(jīng)過Function(Hash(A)) 來計算其分配的實(shí)驗(yàn)田,這樣就能保證層與層之間的流量隨機(jī)且相互獨(dú)立。其流量走勢如下圖所示,

9a8bfa3a-bb81-11ed-bfe3-dac502259ad0.jpg

以上就是推薦業(yè)務(wù)和一般業(yè)務(wù)實(shí)驗(yàn)流量隔離的不同之處,在實(shí)驗(yàn)設(shè)計上我們又將一個完整的實(shí)驗(yàn)周期分為以下幾個階段。在預(yù)備階段需要跟根據(jù)業(yè)務(wù)指標(biāo)的需求,提出實(shí)驗(yàn)假設(shè),劃分好基線和實(shí)驗(yàn)田的流量比例,并上線配置(放量)。

在實(shí)驗(yàn)階段,線上流量進(jìn)入后,服務(wù)會根據(jù)流量號段的匹配響應(yīng)的策略進(jìn)行執(zhí)行,并將實(shí)驗(yàn)數(shù)據(jù)上報。放量一段時候后,我們會根據(jù)上報的埋點(diǎn)數(shù)據(jù)進(jìn)行數(shù)據(jù)分析,以確定此次策略的好壞。

9ac5bc16-bb81-11ed-bfe3-dac502259ad0.jpg

和實(shí)驗(yàn)階段劃分相對應(yīng)地,我們將實(shí)驗(yàn)平臺劃分為實(shí)驗(yàn)配置,埋點(diǎn)上報和實(shí)驗(yàn)結(jié)果分析三個模塊,在實(shí)驗(yàn)配置模塊,我們根據(jù)實(shí)驗(yàn)需求來完成分流配置和業(yè)務(wù)場景的映射關(guān)系。

9ae8ce68-bb81-11ed-bfe3-dac502259ad0.png

并在hash實(shí)驗(yàn)管理中將業(yè)務(wù)層級劃分,以便流量的流通。

9b1981c0-bb81-11ed-bfe3-dac502259ad0.png

在埋點(diǎn)上報模塊中,我們通過sdk的方式植入業(yè)務(wù)代碼中,當(dāng)流量進(jìn)入該實(shí)驗(yàn)田時就會進(jìn)行分析和埋點(diǎn)上報,我們將上報的埋點(diǎn)分為游戲和請求維度,節(jié)省上報流量的同時以滿足不同的分析需求:

游戲維度: { "code": 0, "data": [ { "score": 0.016114970572330977, "data": { "gameId": 53154, "appId": 1364982, "recommendReason": null, }, "gameps": "埋點(diǎn)信息", } ], "reqId": "20200810174423TBSIowaU52fjwjjz" } 請求維度: { "reqId":"20200810142134No5UkCibMdAvopoh", "scene": "appstore.idx", "imei": "869868031396914", "experimentInfo": [ { "experimentId": "RECOMMENDATION_SCENE", "salt":"RECOMMENDATION_SCENE", "imei": "3995823625", "sinfo": "策略信息" }, { "experimentId": "AUTO_RECOMMENDATION_REASON", "salt":"RECOMMENDATION_SCENE", "imei": "1140225751", "sid": "3,4,5" } ] }

在實(shí)驗(yàn)結(jié)果分析模塊中,我們將采集的埋點(diǎn)的數(shù)據(jù)上報只大數(shù)據(jù)側(cè),并由其進(jìn)行分析計算,其結(jié)果指導(dǎo)這我們對實(shí)驗(yàn)策略進(jìn)行進(jìn)一步的分析迭代。對于游戲請求的上報格式,我們可以直接通過appId和gameps的信息直接分析得出該類游戲的推薦結(jié)果和用戶行為的關(guān)系。同時加入請求維度的分析(包含策略信息),可以直接分析出決策對各項(xiàng)指標(biāo)的影響。

4.2 召回優(yōu)化之多路召回

召回在游戲推薦業(yè)務(wù)中就是利用一定的規(guī)則去圈選一批游戲,這是為了將海量的候選集快速縮小為幾百到幾千的規(guī)模。而召回之后的排序則是對縮小后的候選集進(jìn)行精準(zhǔn)排序,最終達(dá)到精準(zhǔn)推薦的目的。

然而這種單路的召回在業(yè)務(wù)上卻有著很大的缺陷:

通常為了保證計算效率,圈選的數(shù)量在幾百個左右,由于數(shù)量限制其無法完全覆蓋完整的目標(biāo)用戶候選集。

隨著業(yè)務(wù)的復(fù)雜度變高,召回策略的種類也開始膨脹,其召回規(guī)則是剝離的無法統(tǒng)一,這也意味著在某些業(yè)務(wù)場景下,在種類上無法覆蓋完全。

9b4ab222-bb81-11ed-bfe3-dac502259ad0.jpg

因此,權(quán)衡了計算效率和業(yè)務(wù)覆蓋度(召回率)的問題,我們逐步上線了多路召回功能。

在業(yè)務(wù)實(shí)現(xiàn)上,多路召回兼容了原有的個性化召回、算法召回、游戲池召回、分類/標(biāo)簽/專題/同開發(fā)者)召回等召回路徑,通過圈選多個游戲池做為召回策略,經(jīng)過合并、過濾、補(bǔ)量、截斷等策略最終篩選出一批進(jìn)行算法預(yù)估打分的游戲。

本質(zhì)上,多路召回利用各簡單策略保證候選集的快速召回,從不同角度設(shè)計的策略保證召回率接近理想狀態(tài)。

9b7b6408-bb81-11ed-bfe3-dac502259ad0.png

4.3 曝光干預(yù)之動態(tài)調(diào)參

一個推薦系統(tǒng)的效能如何,除了運(yùn)營策略之外很大程度上取決于推薦算法的結(jié)果,而推薦算法的結(jié)果又是以曝光量,下載量,ctr等作為評價指標(biāo)的。所以在游戲推薦業(yè)務(wù)的生命周期中,推薦算法一直致力于優(yōu)化這些指標(biāo)。

但是在開發(fā)中有個實(shí)際問題就是,從算法結(jié)果的數(shù)據(jù)反饋,到代碼改進(jìn)上線這個時間周期較長,對一些需要快速響應(yīng)的業(yè)務(wù)場景來說是不符合要求的。因此我們需要一套規(guī)則來對線上的算法結(jié)果做動態(tài)調(diào)整,以滿足業(yè)務(wù)的要求,這就是動態(tài)調(diào)參。

目前游戲業(yè)務(wù)的營收中,曝光量是個極其重要的指標(biāo),而大盤在一段時間內(nèi)的曝光量是確定的,太多或太少都會嚴(yán)重影響業(yè)務(wù),由此推薦算法就會根據(jù)線上實(shí)時反饋的一些數(shù)據(jù)對游戲的曝光進(jìn)行調(diào)整。

9baa2d06-bb81-11ed-bfe3-dac502259ad0.jpg

經(jīng)過設(shè)計, 我們先將調(diào)參游戲劃分為多個等級,并將游戲的生命周期劃分為幾個時間段,同時在每個時間段內(nèi)以游戲曝光量,評級,數(shù)量等因素作為計算因子來計算曝光的分配權(quán)重。

接著系統(tǒng)根據(jù)實(shí)時采集的游戲曝光信息及所計算的游戲目標(biāo)曝光對實(shí)際曝光進(jìn)行調(diào)整,最終實(shí)現(xiàn)游戲曝光的動態(tài)調(diào)控。

對于正向調(diào)控來說,動態(tài)調(diào)參就是最有效的扶持機(jī)制,增加了游戲曝光的同時提升了導(dǎo)流能力。對于負(fù)向調(diào)控,動態(tài)調(diào)參能對品質(zhì)和要求不達(dá)標(biāo)的游戲,通過減少曝光的方式進(jìn)行打壓,提升用戶體驗(yàn)。

五、展望之智能化建設(shè)

經(jīng)過多年的探索實(shí)踐,游戲推薦系統(tǒng)成就了一套完整的推薦體系。

在架構(gòu)上的演進(jìn)使得我們能更好地應(yīng)對復(fù)雜多變的業(yè)務(wù)需求,在精細(xì)化運(yùn)營上的探索與建設(shè)令我們能更加敏銳地把握住市場的變化以做出響應(yīng),這些建設(shè)也很好地反饋的反饋到了業(yè)務(wù)結(jié)果中,提升了眾多效能和收益指標(biāo),得到了業(yè)務(wù)方的一致好評。

但當(dāng)分發(fā)效率和收入效益問題解決了之后,我們在思考自己還能做什么,原先游戲推薦做的比較多的是接入服務(wù),在單鏈路上去做閉環(huán)提高效益,但這是遠(yuǎn)遠(yuǎn)不夠的。

在未來我們會考慮如何打造覆蓋搜廣推+ 智能運(yùn)營的全棧業(yè)務(wù)支撐系統(tǒng)(智能禮券,智能push,用戶反饋智能處理系統(tǒng)),以提升平臺和渠道的價值。

審核編輯 :李倩

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19028

    瀏覽量

    228441
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    6754

    瀏覽量

    88609
  • 算法
    +關(guān)注

    關(guān)注

    23

    文章

    4573

    瀏覽量

    92333

原文標(biāo)題:解密游戲推薦系統(tǒng)的建設(shè)之路

文章出處:【微信號:OSC開源社區(qū),微信公眾號:OSC開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    專業(yè)單片機(jī)解密

    、PCB組裝,樣機(jī)制作調(diào)試,批量加工生產(chǎn)一站式服務(wù)。    2. 單片機(jī)解密,現(xiàn)在的一些控制類主板上都有掉電丟失資料的IC,本公司經(jīng)過
    發(fā)表于 10-08 10:51

    中國智能交通建設(shè)

    現(xiàn)階段,中國智能交通建設(shè)的一個重要特征是——從早期的管控型逐漸向服務(wù)型過渡,其中,車輛導(dǎo)航市場近年來的變化猶為明顯。衛(wèi)星導(dǎo)航作為智能交通系統(tǒng)的核心組成部分之一,在過去更多的是采用靜態(tài)路徑導(dǎo)航的方式
    發(fā)表于 08-03 20:38

    IC解密反向定制強(qiáng)“芯”來襲

    處理的是一個非常大的貨量,那么芯片定制成本經(jīng)濟(jì)問題就可以解決了?! ≈袊箨懻蔀槿蜃畲蟮南M(fèi)電子市場,但在核心芯片、操作系統(tǒng)等關(guān)鍵技術(shù)上仍然沒有擺脫受制于人的局面。在芯片解密邁向成熟的關(guān)鍵時期,反向定制半導(dǎo)體芯片將為中國芯片產(chǎn)業(yè)提供堅實(shí)的技術(shù)支撐,同時也將促進(jìn)中國IT
    發(fā)表于 12-21 16:11

    未來游戲公司發(fā)展之路應(yīng)該注意什么?

    眾所周知,在游戲暢銷版上,霸占版首的是王者榮耀、夢幻西游、陰陽師三款手游, 手游之所以更容易受玩家接受,比起端游來,它更方便,玩家可隨時隨地進(jìn)行操作體驗(yàn),大大提高了便捷性,更多的一個原因是,現(xiàn)在是
    發(fā)表于 03-31 10:56

    未來的芯片解密出現(xiàn)在哪些智慧城市

    工程技術(shù)人員現(xiàn)代化技術(shù)革新、技術(shù)革命的有力武器?!?b class='flag-5'>解密專家+V信:icpojie】 今年上半年第九屆中國智慧城市大會新聞發(fā)布會上住建部總規(guī)劃師唐凱表示“截至目前,我國已有400多個城市宣布建設(shè)智慧城市,覆蓋東、中
    發(fā)表于 06-05 16:44

    開關(guān)解密游戲機(jī)電路圖

    開關(guān)解密游戲機(jī)電路圖
    發(fā)表于 05-19 11:01 ?6次下載
    開關(guān)<b class='flag-5'>解密</b><b class='flag-5'>游戲</b>機(jī)電路圖

    基于MEMS和FPGA的移動硬盤數(shù)據(jù)加解密系統(tǒng)

    基于MEMS和FPGA的移動硬盤數(shù)據(jù)加解密系統(tǒng) 隨著信息量的急劇增長,信息安全日益受到人們重視。一個完整的數(shù)據(jù)加解密系統(tǒng)應(yīng)該 具備安全可靠的密碼認(rèn)證機(jī)制和加
    基于MEMS和FPGA的移動硬盤數(shù)據(jù)加<b class='flag-5'>解密</b><b class='flag-5'>系統(tǒng)</b>

    重裝系統(tǒng)后實(shí)戰(zhàn)EFS解密

    重裝系統(tǒng)后實(shí)戰(zhàn)EFS解密 公司一位同事的電腦中病毒,無藥可救,幫她還原系統(tǒng)后才發(fā)覺她的D盤有部分文件無法打開使用,原因是這位MM竟
    發(fā)表于 01-11 11:29 ?1.2w次閱讀

    基于CH375的USB文件加解密系統(tǒng)設(shè)計

    介紹了采用CH375 與單片機(jī)實(shí)現(xiàn)的基于USB HOST 技術(shù)的嵌入式文件加密解密系統(tǒng),該系統(tǒng)采用基于隨機(jī)算子的輕量級加密算法對USB 移動存儲設(shè)備中的文件進(jìn)行加密解密。
    發(fā)表于 05-17 15:43 ?32次下載
    基于CH375的USB文件加<b class='flag-5'>解密</b><b class='flag-5'>系統(tǒng)</b>設(shè)計

    CA 解密系統(tǒng)原理及流程

    此篇文章主要解釋了CA 解密系統(tǒng)原理及流程,非常形象易懂
    發(fā)表于 11-10 15:34 ?4次下載

    BenOS實(shí)時操作系統(tǒng)解密

    BenOS實(shí)時操作系統(tǒng)解密BenOS實(shí)時操作系統(tǒng)解密BenOS實(shí)時操作系統(tǒng)解密BenOS實(shí)時操作
    發(fā)表于 01-12 10:54 ?5次下載

    素數(shù)階群上快速解密的KP-ABE方案

    構(gòu)造,解密運(yùn)算時雙線性配對計算開銷過大的問題,提出一種素數(shù)階群上快速解密的密鑰策略ABE( PFKP-ABE)方案。首先基于對偶正交基和線性秘密共享( LSSS)技術(shù)提出一個PFKP-ABE方案,然后采用對偶系統(tǒng)加密技術(shù)構(gòu)建一系
    發(fā)表于 12-21 14:44 ?1次下載

    如何設(shè)計網(wǎng)絡(luò)傳輸信息加密解密系統(tǒng)

    公鑰密碼體制的基本思想是:密鑰分為加密密鑰E,解密密鑰D和公鑰M。加密密鑰E和公鑰M可以公開,D不能公開。加密時采用以E,M為參數(shù)的函數(shù)f1(E,M)進(jìn)行加密,解密時采用以D,M為參數(shù)的函數(shù)f2(D,M)進(jìn)行解密
    的頭像 發(fā)表于 09-14 09:09 ?3437次閱讀
    如何設(shè)計網(wǎng)絡(luò)傳輸信息加密<b class='flag-5'>解密</b><b class='flag-5'>系統(tǒng)</b>

    單片機(jī)解密原理_單片機(jī)解密方法

    單片機(jī)解密又叫芯片解密,單片機(jī)破解,芯片破解,IC解密,但是這嚴(yán)格說來這幾種稱呼都不科學(xué),但已經(jīng)成了習(xí)慣叫法,我們把CPLD解密,DSP解密
    的頭像 發(fā)表于 11-04 09:05 ?1.1w次閱讀

    芯片為什么要解密 解密芯片的方法

    芯片解密服務(wù)也叫IC解密,單片機(jī)解密,分析競爭激烈市場里的先進(jìn)芯片,并對其片內(nèi)結(jié)構(gòu)進(jìn)行解密研究,再創(chuàng)新設(shè)計制造,產(chǎn)學(xué)研在這里找到了全新的結(jié)合點(diǎn)。 芯片
    的頭像 發(fā)表于 12-29 10:45 ?5358次閱讀