阿里、蚂蚁、晟腾、中科加禾精彩分享 AI 基础设施洞见,现购票可享受 9 折优惠 |AICon 了解详情
写点什么

蜻蜓 FM 信息流推荐探索与实践

  • 2021-06-08
  • 本文字数:3094 字

    阅读完需:约 10 分钟

蜻蜓FM信息流推荐探索与实践

如今的推荐系统在互联网中随处可见,无论是刷抖音、逛淘宝还是看新闻背后都有强大的推荐系统的支持。音频行业的内容如何分发?如何提高用户发现音频内容的效率?蜻蜓 FM 作为国内首家互联网音频媒体平台,在音频行业深耕了 10 年,对此也有一些沉淀和经验想要和大家分享。



主要内容包括:

  • 蜻蜓首页场景怎样从人工运营演进到个性化推荐

  • 蜻蜓信息流推荐由哪些算法组成,彼此怎么配合

  • 整体推荐系统架构及算法模型如何部署到线上

  • 蜻蜓信息流推荐场景后续发展的一些思考

场景

1. 人工推荐时期


早期蜻蜓首页流量的分发是以模块形式展示,每个模块可配置横排和竖排的个数。此时只有个性推荐模块的内容由推荐算法生成,其他模块则是由运营人工维护。模块中的内容需要运营定期进行更换,展示内容的更新完全依赖人工,效率显得很低。


为了提高运营人工工作效率,我们引入了策略推荐。

2. 策略推荐时期

策略推荐时期运营的工作由之前每天更新模块中的内容,变成了为模块绑定内容库和选择合适的排序策略。内容库中的内容是由配置的分类、属性动态生成和更新,运营为单个模块的配置基本可以做到了一劳永逸。



模块之间怎么排序?模块中的内容排序策略怎么选才能收益最大化?成了新的挑战。

3. 个性推荐时期


通过数据发现个性推荐模块效率高于其他策略推荐的模块,首先尝试了扩大个性推荐模块中内容的数量,由 3 个变 6 个。验证了对首页整体效果有提升后,把多个模块合并成一个信息流的个性化推荐的想法应运而生,线上 AB 实验结果表明信息流的个性化推荐各项指标均高于多个模块的策略推荐。信息流的形态是单排还是双排?经过 AB 实验,最后选择了效果更优的双排。



个性推荐时期运营对于少数专辑依然会有流量扶持、推广的的述求,在个性化推荐的基础上增加了投放系统。投放系统中还支持通过不同标题、封面对单个投放计划生成多个创意,多个创意之间数据表现好的沉淀下来推广到更多的场景中。运营不再局限于选择内容,更为重要的是重新组织创造了内容,充分发挥出了运营在想象力、创造力上的价值。

4. 小结


首页场景经历人工推荐、策略推荐、个性推荐三个阶段。策略推荐基本解决了人工效率问题,个性推荐进一步解放人力的同时也带来了数据指标的显著提升。

算法

伴随着首页场景的演进,蜻蜓的推荐算法也在不断的完善和迭代。

1. 推荐算法流程


推荐算法的流程大致如下:内容池中达到推荐标准的内容的有几十万个,召回层从中选出用户可能喜欢的几千个进入粗排层,召回层的覆盖度决定了整体推荐内容的覆盖上限。粗排层从召回结果中挑选出几百个给到精排层,粗排层主要为了减小在线算力减轻精排的压力。精排层选几十个给到重排层,精排层专注于推荐的准确性。最后,重排层对推荐结果进行重新排序给到用户,这一层兼顾准确性的同时还需要保证多样性。


级联结构简单,分工明确。兼顾了覆盖度、性能、准确性和多样性。

2. 多路召回


熟悉了推荐的算法的大致流程后,首先,我们来了解一下多路召回。多路召回在蜻蜓主要分为三类:基于内容、协同过滤和 Embedding 向量召回。基于内容的召回包括热门、属性、上新策略的召回;协同过滤包括 User Based 和 Item Based;Embedding 向量召回有 Word2vec 和 Bert。召回环节处理的数据量大,复杂度不能太高,多路召回的设计可以方便加入新的策略或者算法。我们在实践中发现,早期建立完善指标,追踪每路召回的效果,有助优胜劣汰;召回的效果并不是召回算法越复杂越好,不同的业务特点不一样适合的召回也可能不一样,比如蜻蜓当下表现最优的召回来自 ItemCF 和热门;随着召回的算法越加越多,新的召回需要与现有召回有差异性、互补才会有存在的价值。召回环节还会承载业务及平台建设的使命比如用户和物品的冷启动、业务流量扶持等,召回环节的好坏直接决定了后续环节的上限。

3. 粗排


接着是粗排,早期的推进系统中粗排常常用简单的融合策略进行,实践中发现粗排中引入算法是值得的。策略的组合较多测试周期长,双塔模型的应用既解决了多路召回组合的效率问题,又避免了精排的性能问题。


双塔模型扩展性好便于自由添加自定义的网络,User 和 Item 塔解偶,同时点积的计算所需算力小。在蜻蜓为了保障粗排推理数据的实时性,User 向量的生成及点积的计算都是实时的。粗排的加入在数据指标指标上也获得了不错的收益,其中信息流 UV 收听转化率增加了 3.54%,人均收听时长增加了 5.44%。

4. 精排


然后是精排,精排往往在推荐系统中最受关注,精排直接对准确性负责,相对容易拿到直接的收益。我们在精排的投入相对较大,从中获得的收益也相对颇多。蜻蜓的精排经历了三个阶段:线性模型的逻辑回归和 FM、树模型的 XGBoost 以及神经网络模型的 DeepFM。



XGBoost 迭代时间最久,其中模型参数的调优、特征挖掘(包括交叉特征和实时特征的引入)、日志数据的准确性优化以及实时排序,这些整体给在线收听数据带来了近 35%的提升。XGBoost 之后我们尝试过许多模型包括 XGBoost+LR,Wide&Deep 等均没有取得预期的收益,在 DeepFM 上的尝试探索则获得了 9.3%收听相关指标的提升。DeepFM 顺理成章地成为了精排模型的主力,也开启了蜻蜓推荐算法在深度学习道路上的大门。

5. 重排


最后是重排,重排跟召回一样承载了很多业务向的目标和期许。这里主要讲一下多样性,提升多样性一方面希望打破推荐系统的信息茧房,另一方面也希望提升用户的长期使用体验。开始是通过打散策略实现,当前主要是 MMR 和 DPP 两个算法在尝试迭代,实验中 MMR 表现优于 DPP,这里简单介绍一下。MMR(Maximal Marginal Relevance)最大边际相关性算法,保证相关性的同时提高多样性。通过λ参数来调节多样性和相关性的权重,λ越大相关性越高,λ越小则多样性越高。



MMR 算法中有两个相似度,用户和物品的相似度用精排的打分值来表示,物品之间的相似度基于协同过滤的物品相似度。重排的预期是达到帕累托最优,在其他指标都不降低的情况下,提升多样性指标。



最终也达到了预期,人均曝光专辑数量增加 8.84%,人均收听二级分类数量提升 7.06%。

架构

1. 整体架构


推荐系统能高效稳定地运作,离不开优秀的架构支持。蜻蜓的推荐架构是典型的三层架构,即离线、近线、在线三层。离线层负责数据的处理、模型的训练以及数据报表;近线层实时特征处理、召回、粗排;在线层承载了用户请求响应、精排、重排以及投放系统等业务逻辑。

2. 算法模型部署


算法模型如何高效地部署到线上?是算法和工程同学共同面临的挑战。开始的时候我们的模型预测服务和推荐 API 都是用 Golang 实现,特征的获取处理在推荐 API 测完成,模型预测服务负责加载模型并对对获取的数据进行预测。在线特征拼接处理使用 Golang,离线特征拼接处理使用 Scala,跨语言的对齐与校验耗费了开发很多的时间。离线和在线能否公用一套算子进行特征的拼接与处理?为此我们将模型预测服务切换成了 Scala 的 Play 框架,基于 Scala 开发出了一个 feature 获取处理的库,给 Spark 和 Play 共同使用,保证了特征处理逻辑层面的一致性。同时,模型预测服务中增加了对多模型、多版本的支持以及模型的自动更新进一步提高了模型部署的效率。

展望


首页信息流推荐从 0 到 1 建立起来,迭代、优化、完善到现在取得了不错的增长,面向未来还有许多工作需要我们去尝试和探索。内容方面,如何帮助新品内容一步一步变成曝款,产品、研发、运营如何合作建立出完善的内容生态系统;业务方面,信息流支持的业务越来越多包括专辑、直播、听单、节目、广播等,多业务如何更好的融合在一起也是一个挑战;用户方面,新用户的冷启动,沉默用户、潜在流失用户如何激活还有很长的路要走;算法方面,模型的训练如何做到更加实时,多目标的排序是否有望代替单目标排序。这些都将是我们接下来探索的方向。


本文转载自:DataFunTalk(ID:dataFunTalk)

原文链接:蜻蜓FM信息流推荐探索与实践

公众号推荐:

跳进 AI 的奇妙世界,一起探索未来工作的新风貌!想要深入了解 AI 如何成为产业创新的新引擎?好奇哪些城市正成为 AI 人才的新磁场?《中国生成式 AI 开发者洞察 2024》由 InfoQ 研究中心精心打造,为你深度解锁生成式 AI 领域的最新开发者动态。无论你是资深研发者,还是对生成式 AI 充满好奇的新手,这份报告都是你不可错过的知识宝典。欢迎大家扫码关注「AI前线」公众号,回复「开发者洞察」领取。

2021-06-08 07:001507

评论 1 条评论

发布
暂无评论
发现更多内容

URL Manager Pro for Mac(浏览器标签管理应用)v6.4.1激活版

iMac小白

做服务的架构陷阱,你掌握了多少

华为云开发者联盟

后端 开发 华为云 华为云开发者联盟

未雨绸缪,天翼云云备份护航企业稳健发展

Geek_2d6073

AI数字人短视频添加背景教程!(数字人SaaS系统或剪映)

青否数字人

数字人

文心一言 VS 讯飞星火 VS chatgpt (151)-- 算法导论12.2 7题

福大大架构师每日一题

福大大架构师每日一题

如何最大化利用虚拟主机:实用技巧与建议

一只扑棱蛾子

虚拟主机

AI数字人在小红书开播教程!

青否数字人

数字人

专业视频调色软件达芬奇DaVinci Resolve Studio 18激活中文正式版

胖墩儿不胖y

Mac软件 视频剪辑工具 视频后期处理工具 Mac软件视频编辑

怎样防止数字人直播被判定为录播?

青否数字人

数字人

Macs Fan Control Pro for mac( 电脑风扇控制软件)v1.5.16中文激活版

iMac小白

图形化编程平台对比:iVX 与 Blockly/Scratch

代码生成器研究

轻松掌握!作为产品经理,手把手教你使用API接口获取拼多多商品详情

Noah

中企出海 | 引领全球税务治理,助力中企出海

用友BIP

中企全球化

鹏华基金核心系统完成国产化升级,腾讯云大数据TBDS再拓应用新场景

腾讯云大数据

TBDS

低代码正在改变软件开发方式

互联网工科生

软件开发 低代码 JNPF

【腾讯云 HAI域探秘】整合腾讯云HAI的ChatGLM模型到NUXT官网:实现智能IM功能

攀登者

手把手带你配置一个DHCP服务器 | 京东云技术团队

京东科技开发者

网络协议 服务器 Wireshark DHCP

浅析MySQL代价模型:告别盲目使用EXPLAIN,提前预知索引优化策略 | 京东云技术团队

京东科技开发者

MySQL 数据库 索引优化 EXPLAIN

Dropzone 4 for mac(文件拖拽增强工具)v4.80.4激活版

iMac小白

生产环境质量保障的四大挑战

老张

质量保障 测试右移

使用 KubeRay 和 Kueue 在 Kubernetes 中托管 Ray 工作负载

字节跳动云原生计算

ray KubeRay

亚马逊云科技宣布推出三项无服务器服务创新

财见

localhost工具:本地代码的远程之路 | 京东云技术团队

京东科技开发者

HTTP 内网穿透 go语言 localhost

专业统计分析绘图软件:GraphPad Prism 10 激活最新版

mac大玩家j

数据分析工具 Mac软件 数学分析软件

去哪儿如何实现故障率降低65%?技术+管理的数字化度量体系实践

TakinTalks稳定性社区

从 MLOps 到 LMOps 的关键技术嬗变

百度Geek说

大模型 MLOps 12 月 PK 榜 Prompt LMops

搭建本地http服务器-打开本地文件

Lemoon Can

notion链接脑图 mac开机自启动服务 打开本地文件的http服务器

MySQL数据库中SQL语句分几类?

小魏写代码

Solidity之旅(七)单位以及全局变量

BSN研习社

测试用例设计方法六脉神剑——第二剑:招式组合,因果判定出世 | 京东物流技术团队

京东科技开发者

测试 因果图法 判定表法

活动预告 | 中国数据库联盟(ACDU)中国行第四站定档西安,邀您探讨数据库前沿技术

墨天轮

数据库 postgresql oceanbase 国产数据库 KaiwuDB

蜻蜓FM信息流推荐探索与实践_架构_DataFunTalk_InfoQ精选文章