快手雙邊市場的複雜實驗設計問題
01 問題背景
1. 雙邊市場實驗介紹
雙邊市場,即平臺,包含生產者與消費者兩方參與者,雙方相互促進。比如快手有影片的生產者,影片的消費者,兩種身份可能存在一定程度重合。
雙邊實驗是在生產者和消費者端組合分組的實驗方式。
雙邊實驗具有以下優點:
(1)可以同時檢測新策略對兩方面的影響,例如產品 DAU 和上傳作品人數變化。雙邊平臺往往有跨邊網路效應,讀者越多,作者越活躍,作者越活躍,讀者也會跟著增加。
(2)可以檢測效果溢位和轉移。
(3)幫助我們更好得理解作用的機制,AB實驗本身不能告訴我們原因和結果之間的關係,只能告訴我們所作事情會得出什麼樣的影響以及資料變化。但是生產端與消費端之間的作用機制,就需要更加複雜的實驗設計和更多的實驗指標才能把這些問題看清楚。
2. 雙邊實驗的例子
這裡透過一個直播美顏的例子,幫助大家進一步理解雙邊實驗。
假設在直播場景中加上美顏的效果。從表格中橫著看,兩行的實驗的觀眾組,控制觀眾是否可以看到直播美顏前後的差異。表格中的列表示主播有沒有美顏對實際的影響。將以上兩方面結合,當且僅當實驗組主播對照實驗組觀眾時,才給影片開美顏功能。實際另外三個組無法看到美顏功能。但是 BC 看不到美顏,和 D 看不到美顏存在區別。AD 的區別是常規的 AB 實驗的常見場景。本場景透過雙邊設計可以觀察到觀眾側是否存在溢位。
針對主播美沒有美顏功能,若不存在觀眾溢位,則 BD 應該資料表現一致,但實際上,資料 BD 若存在差異,如果主播沒有美顏功能,觀眾在其他主播側看到美顏功能,則實際效果就存在了正影響或者負影響。同理,主播側的溢位也可以透過此種雙邊實驗,更好理解實驗中的作用機制,和實驗雙方是否存在溢位。
02 激勵策略的挑戰
供給側-消費側生態體系內部,業務時長有政策性流量扶持的需求,這就是激勵策略,主要包括以下三種場景:
(1)運營引入優質作者,但不確定作者在平臺上的資料表現;
(2)某些業務需要挖掘特定型別作者,給一些宏觀調控上的流量扶持,予以更強的流量分發力度;
(3)平臺意志場景下,按照某種特定方向發展,認為改變流量分配方式強化某些對應內容供給。
在以上場景下往往並非網路學習的方式,而是透過人為的角度對平臺流量做宏觀的調控。針對關注相對長期的,需要觀察學習效應(促生產等),時間片輪轉之類的方法不太試用。例如如下場景:給一類定向流量的作者流量的支援,來研究這樣的流量在長期場景下,互動以及生產是否可以長久。
首先是作者側的擠佔:大多數此類實驗,平臺的總曝光數量有限,平臺扶持的場景下,實驗組作者曝光增加,不被扶持的對照組曝光量減少。若作者側冷啟動曝光提升幅度比讀者側冷啟動曝光幅度更大,就證明存在擠佔情況。
根據上圖根據實驗組對照組關係以及開展各組曝光相對基線 diff,可以看出,隨著實驗開始對作者 boost 最後會透過推薦系統不僅傳遞給使用者組 B 也會傳遞給使用者組 A,並且作者 B 使用者 B,作者 B 使用者 A 的曝光 diff 是基本趨於一致的。傳統實驗一直致力於對此種策略扭曲的流量情況矯正。
SUTVA 假設,個體 i 在實驗過程中只與自身被分配在實驗組或者對照組相關,與實驗體系下其他節點在哪個分組無關,不論其他節點是合作關係還是競爭關係。SUTVA 是 AB 實驗得到有效結論最基礎的假設。
實際雙邊網路違背了 SUTVA 假設。
在短影片場景下,如果把每一種記錄策略看作一種排序演算法。不同的激勵策略代表短影片的不同排序結果。上圖 RC 代表對照組,RT_25% 實驗組流量是 25% 時的演算法排序組合,RT 代表實驗組實驗推全 100% 演算法排序組合。BCDE 為實驗目標使用者型別,即被選中的激勵作者作品。而 D 為當實驗推量 25% 時,正好落在實驗組中。假設透過推薦加權的方式實驗,D 的排序直接排到前面位置。若策略增加至 100%,BCDE 均被加權,這種情況,D 作品卻排序反而下降。這種場景就是實驗組擠佔,以及出現擠佔的原因。
03 可選解決方案
1. 方案1:逐步擴量
實驗組排序 gap 會隨著實驗組資料比例擴大而逐漸接近,擠佔的效應隨著對照組流量減少而減少。
【先發優勢】實驗過程中發現,針對流量扶持的場景下,相等扶持力度,先扶持作者會始終保持流量優勢。更早的扶持和加速發掘過程本身邏輯是前後一致的。
分階段擴量的實驗詳情:上圖展示了分階段擴量,縱座標為相對 base 組漲粉資料差異。實驗初期,20% 實驗組的情況,只扶持了實驗組 1,實驗組一資料指標開始上升;當實驗放量 60%,實驗組 123 均開始扶持,另外兩組實驗指標也開始上升,但始終沒有超過實驗組 1;後面將實驗組改成了 124,發現 4 也開始提升,但是 4 仍然無法超過實驗組 3。
由此可以得出以下結論:逐步擴量是有用的,指標會根據擴量提升,提升會不會隨著流量擴大而變小則無法確認。目前實驗結果可以得出,先獲得流量扶持的實驗組資料表現會比後獲得流量扶持的實驗組更好。
2. 方案2:劃分小世界
如上圖所示方法,將實驗組和對照組完全隔離,實驗組讀者只能看到實驗組作品,控制組讀者只能看到控制組作品。由此避免出現作者和讀者之間的擠壓情況。
類似的做法有,將作者和讀者的流量分發當成一個網路圖,這個網路圖並不是處處聯通,部分讀者只愛看部分幾類作品,基於這樣的網路圖可以做實驗組對照組的切分。以上做法與劃分小世界方式思路一致,實踐效果更好,但與此同時也具有更大的計算成本。
劃分小世界主要存在的問題為:
(1)演算法推薦系統需要一定的規模量級才能冷啟動,當切分池子一定小的時候,影響實際個性化分發空間。不同業務不同平臺保留推薦彈性效果前提下,對切分結構最細粒度要求各不相同。大多數情況,推薦邊際效應遞減。
(2)明確的流量隔離,會對樣本進行的實驗數量和檢驗方式有一定限制。針對並行實驗場景需要不斷得將隔離開的使用者重新打散重新拆分。
從分析方法中矯正而不是實驗設計的方式矯正:
根據實際網路效應做矯正分析;
根據實驗結果做一些線性假設以及其他的一些條件假設。
採用實驗方式矯正的原因:
首先實際的分析矯正方法中假設很難驗證,對於差異較大的實驗,網路效應的溢位擠佔情況各不相同,很難在短時間內總結規律,無法得到通用方法。而實際我們的解決方案希望可以解決一大類問題。
04 構建綜合方案
基於排序融合的方案構建——本質上我們希望可以保證實驗組 RT_a% 的排序和實驗組RT_100% 的實際排序可以保持一致結果。
實現方式:首先同時用 RT/RC 兩套排序演算法進行排序,記錄對應的作品順序;將作者分為實驗組和對照組,對於實驗組給讀者展示的為兩個演算法的排序融合順序。
將 RC 為當前所有作者均沒有扶持的線上排序方案,RT 中將所有知識類作者提權。將RC 於 RT 的排序結果融合,先將實驗組 RT 對應的作者(T1T2)放在 final 分組的對應排序位置上,將對照組的作者根據原先實驗無關的次序繼續保留。保守起見,小流量時期建議除了實驗作品以外,其他作品均按照原先次序填充。若實驗已經推全,則全量使用 RT 的結果。
如果實驗組和對照組競爭同一個位置怎麼辦?
根據以上實驗設計,如果出現實驗組作品和對照組作品競爭同一個位置,最簡單的方式是隨機選擇。這種情況出現的機率很低。
如果實驗組和對照組都是 a% 的總流量,假設 a=2,
假設一次推 10 個作品,top10 同時出現實驗組和對照組作品的機率計算如上圖,約為 3.3%。如果兩個演算法完全獨立,前 10 相同位置出現衝突的機率更低。
往往改進具有一定的漸進式的,RC 和 RT 關聯性很高,衝突性更小。於此同時也可以透過離線測試的方式提前預估衝突的機率。
以上雙邊實驗主要的指標評估可分為以下三類:
作者側指標:作品數量,生產作者數,直接從作者側檢驗;
報告觀看量指標:CTR,EVTR,作者作品曝光提升=讀者觀看次數提升進行推算;
讀者側指標:讀者側單邊實驗驗證。
方案可能存在其他一些問題:
首先任何的方案都會存在問題。雙邊市場強的溢位效應很難透過一個解決方案解決所有問題。
目前實驗設計的主要問題包括以下幾個方面:
(1)首先,保留兩套排序從工程側存在一定成本,若政策激勵會更好推進,演算法的角度不容易一直保持兩套不做融合;
(2)其次,從演算法資料的隔離的角度,部分改進來自於資料本身,模型本身存在較大變化,結果排序演算法邏輯不再成立。
(3)第三,計算假設 a=2%,如果更多的流量檢驗小的效果是否可以增加 a 值?隨機選擇比例混排,使得更大流量衝突可能性更小。最後,雙邊問題退換為單邊來解決,是否可以透過雙邊可以解決,待後續繼續探究。
來自 “ DataFunTalk ”, 原文作者:程大曦;原文連結:http://server.it168.com/a2023/0314/6793/000006793793.shtml,如有侵權,請聯絡管理員刪除。
相關文章
- 廣告場景下雙邊市場的實驗設計
- 貨拉拉貨運雙邊市場實驗全景解讀
- 京東重返雙邊市場
- QOJ6958-複雜的雙樹上問題以及簡單的解決方式
- nuget使用經驗:複雜依賴關係下的包版本問題
- HarmonyOS 應用中複雜業務場景下的介面設計
- 被騰訊問蒙的各種Redis複雜問題Redis
- 複雜的資料結構設計求解?資料結構
- 用 JMeter 做複雜介面測試遇到的問題JMeter
- 資料結構,雜湊表hash設計實驗資料結構
- AliAGC 自動增益控制演算法:解決複雜場景下的音量問題GC演算法
- 複雜多邊形的三角剖分
- 複雜任務中,流程的解耦設計解耦
- 面對複雜問題時,系統思考助你理解問題本質
- 架構設計複雜度的6個來源架構複雜度
- 分散式重複提交問題架構設計思路分散式架構
- 複雜多變場景下的Groovy指令碼引擎實戰指令碼
- 1688 複雜業務場景下的 Serverless 提效實踐Server
- 程式設計謎題:提升你解決問題的訓練場程式設計
- 六邊形架構:管理複雜性的解決方案架構
- 重構複雜條件的規則設計模式 - levelup設計模式
- 使用橋接模式設計複雜的訊息系統橋接模式
- 針對複雜系統的雙環模型之指南模型
- 萬智牌設計雜談:重複利用(上)
- 萬智牌設計雜談:重複利用(下)
- 複雜報表設計之動態報表
- 時間複雜度的計算時間複雜度
- 面試題35:複雜連結串列的複製面試題
- 實踐篇 | DDD概念複雜難懂,實際落地如何設計程式碼實現模型?模型
- 複雜場景資料處理的 OLTP 與 OLAP 融合實踐
- 在複雜領域中設計軟體:領域驅動設計 - levelup
- 記一個複雜元件(Filter)的從設計到開發元件Filter
- 為了實現線上庫的複雜查詢,你還在雙寫嗎?
- 害怕軟體的複雜嗎?其實複雜性是必須存在的 - ferd
- 迴圈結構程式設計 實驗題目程式設計
- oracle 開啟複雜密碼驗證Oracle密碼
- 雙十一雲起實驗室體驗專場,七大場景,體驗有禮
- 使用ajax請求傳送複雜的json資料型別,並解決fastjson解析複雜的json資料型別的問題JSON資料型別AST