广告算法在阿里文娱用户增长中的实践
导读: 从 2019 年开始,优酷使用 DSP 在今日头条、阿里妈妈等平台投放视频广告,实现用户的稳定增长。我们将 用户增长领域与广告竞价领域结合,借鉴推荐领域的实践,基于特有的业务背景,开发落地了一系列算法。 在成本及预算可控的条件下,最终实现了 数百万 DAU 的引流能力。本文主要介绍外投广告算法在用户增长领域的设计及优化,解决存在约束的条件下,实现最大化 DAU 量的问题。
下面将围绕四点展开:
- 优酷用户增长业务介绍
- 广告排序算法及优化
- 自动化报价算法
- 总结及后续规划
1. 用户增长业务背景
在用户增长的过程中,首先需要把用户增长划为不同的用户态,不同的用户态存在不同价值。**新用户会变为低活用户、中活用户直至高活用户,在整体过程中,也会随时变成沉默用户。**对用户增长而言,新用户、低活用户和沉默用户是非常有价值的,他们的到访能有效提高 APP 的活跃度。
RTB 是实现用户增长的主要方式之一。 它的主要流程是:首先 DSP 参与广告竞价,在竞价成功之后,广告会展现在外部平台上,用户在点击之后会切换至优酷 APP 上,如果感兴趣的话会有视频消费和次日回访。整个流程分为两部分,前半部分归属于 RTB 竞价,后半部分属于用户增长。
用户增长的主要业务目标是在成本可控的条件下,最大化高价值的 DAU 量,即让更多的新用户、低活用户以及沉默用户来到平台进行消费,增加平台活跃度。
2. 广告竞价 RTB 概述
RTB 有两个比较重要的组件:广告主竞价代理 DSP 和提供竞价接入、判定竞价成功与否的平台 ADX ( 例如头条 ADX,阿里的 TanX )。
RTB 过程如下:当用户访问的 Web 页面或 APP 应用时,请求发送至 ADX,由 ADX 转发至多个 DSP,DSP 根据从用户需求平台 ( DMP ) 上取得的用户特征进行预估,在 100ms 之内将广告和出价返回至 ADX,之后 ADX 根据多个 DSP 返回的结果,根据一定的排序规则和计费规则,选择一个合适的广告投放给用户,之后又将用户是否点击这条广告的信息返回给成功获得了该次竞价的 DSP 代理。
RTB 中的主要关注点是成交机制和计费模式,其中成交机制包括:GFP ( 最高价格成交 ), GSP ( 第二价成交,通用的方式 ), VCG ( 通过效用计算成交价格,存在算法上,理解上的难度,用的较少 )。计费模式主要有 CPM,CPC,CPA 和 OCPX,其中 CPM 是由广告主承担预估风险,由 DSP 预估用户对广告主的价值,CPC 和 CPA 是由平台来预估用户对于各个 DSP 的价值,OCPX 是由平台自动调整出价,由平台预估价值,用户承担风险。
在我们的业务场景中,使用的是 GSP 成交机制,CPM 的计费模式。并且优酷业务场景有鲜明的特点:
- 使用 CPM 计费,需要我们自身建模预估,但可利用站内数据;
- 对于不同用户态的拉活,引流成本是不一样的,需要针对不同人群提供成本控制;
- 作为只有一个用户的 DSP 代理,可以接入不同的 ADX 平台,需要针对多渠道多平台做模型融合。
虽然现有的 ADX 平台能够支持直接在上面投放广告,但是存在很多问题:不支持定向用户分层,不支持个性化,数据属于平台方,无法进行后续优化,接入平台过多也会增加消耗等等,因此我们自建 DSP,满足业务场景需求。
1. 算法流程
离线产生数百万的广告,第一步通过人工精选或者算法选择来保证广告池的动态进出,例如删除投放时间过长,点击率过低的广告,通过算法选择高质量的广告;第二步通过个性化多路召回适合用户的千百个广告;第三步将经过召回的广告通过规则过滤,例如会过滤重复广告,或者会根据曝光频率来控制;第四步将这些广告通过预估模型,选择价值最高的广告通过报价算法产生报价,最后将广告和报价结果返回至 ADX。
与推荐系统相比,流程借鉴了推荐系统的多路个性化召回,区别在于推荐系统关注 Rank 顺序,而广告还关注 CTR 偏差,推荐系统一般最后的组件是重排 ( ReRank ),而广告系统在预估之后需要进行报价计算。
2. 算法实现方案
我们面对的业务场景的主要特点是:
- RT 限制比较严格,要在 100ms 内返回;
- 存在多渠道多平台;
- 接入量大,机器资源比较紧张。
常用的排序模型有 LR,GBDT,DNN ( DCN/WDL/MMOE ) 等,LR 需要大量的特征工程工作来提高模型精度,GBDT 的训练和预估都很快,能有效缓解 RT 问题,但是类别特征的处理上容易使模型过拟合,DNN 的 embedding 技术能够处理各种特征,但是由于需要存储包含每个特征对应的 embedding 的大矩阵,线上内存消耗很大,而且 DNN 类的模型虽然能达到很高的精度,但训练和预估都很耗资源并且打分时的 RT 很高。
在多渠道多平台统一模型方面,主要存在两个问题:
- 不同渠道之间有差异。例如汽车相关广告,在母婴社区和汽车之家论坛点击率之间会有不同;
- 渠道平台相关没有现成的特征。在实际中,我们以平台本身作为特征,通过根据历史数据构建不同平台的统计特征,使模型感知到渠道平台的差异,最后基于不同平台不同分层的 Match 特征,实现了由 LR 单渠道模型到 GBDT 统一模型的升级,带来了业务上的明显收益。
3. 遇到的问题和思考
推荐中常用召回都是 Item-based,通过用户观看的视频来寻找相似的视频,认为这些相似视频是用户喜欢的视频,这导致推荐系统有以下缺陷:
- 用户观看的视频未必是用户喜欢;
- 相似视频的相似之处未必是用户观看视频的真正原因;
- 低频用户观看的视频非常少,推荐结果缺乏多样性。
从因果推断的角度思考上述问题的话,我们认为用户变沉默的原因是对之前推荐的内容不满意,而用户留存的原因是因为推荐的视频他比较喜欢,因此,我们 利用无偏信息构建相似度量,构造低活用户到高活用户的匹配,找到他的反事实镜像人,然后进行相关推荐,在业务上也取得了很大收益。
1. 业务背景及问题的形式化定义
不同的场景下,广告投放的报价算法存在不同的约束,主要场景包括日常投放和冲量投放,本质上都是多渠道多分层的投放。对于日常投放而言,会存在预算约束,首活成本约束,用户价值约束 ( 需要去高活,要更多的高质量沉默用户 );当运营有冲量需求时为冲量投放,这时预算充足,有首活成本约束,用户价值约束。
2. 单 PID 解决冲量投放
根据冲量投放的条件:预算充足、有首活成本约束、用户价值约束,可以解出报价公式,即报价为预估的 CTR/CVR 与报价系数 alpha 之积。我们通过单控制器的方法来控制报价系数
- 原文作者:知识铺
- 原文链接:https://geek.zshipu.com/post/%E4%BA%92%E8%81%94%E7%BD%91/%E5%B9%BF%E5%91%8A%E7%AE%97%E6%B3%95%E5%9C%A8%E9%98%BF%E9%87%8C%E6%96%87%E5%A8%B1%E7%94%A8%E6%88%B7%E5%A2%9E%E9%95%BF%E4%B8%AD%E7%9A%84%E5%AE%9E%E8%B7%B5/
- 版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议进行许可,非商业转载请注明出处(作者,原文链接),商业转载请联系作者获得授权。
- 免责声明:本页面内容均来源于站内编辑发布,部分信息来源互联网,并不意味着本站赞同其观点或者证实其内容的真实性,如涉及版权等问题,请立即联系客服进行更改或删除,保证您的合法权益。转载请注明来源,欢迎对文章中的引用来源进行考证,欢迎指出任何有错误或不够清晰的表达。也可以邮件至 sblig@126.com