转自:网易云首次披露推荐算法:让单身狗犹如过情人节的日推原来是这样生成的
作者:宇多田
侵删


网上各种关于网易云音乐的个性推荐算法的详解五花八门,但是官方从未现身说法!
为了解开用户们对每日推荐歌单背后算法的好奇心,我们闯进网易云音乐总部里的产品与技术部门,挟持了技术专家,把我们心中的疑惑全都吐了出来。
撰文 | 宇多田
编者按:老铁们,知道今天是什么日子吗?
明知应该说声节日快乐,但咱们也不能忘记在寒冷狗窝里坐等国家分配的单身汪们(仿佛说的不是我自己)。
今天一早,当发现朋友圈撒的狗粮已经够吃 1 年后,我还是打开了网易云音乐,想在热闹的评论区寻找同类:另一群单身狗们。
没想到,他们除了搞出个【单身元年特别访谈】,「每日推荐」给我推的第一首歌竟然是:
The Best Day of My Life(我人生中最好的一天)。
……
好吧,歌词「我不会自暴自弃,不要唤醒我,这是我人生中最美好的一天」,让我严重怀疑,网易云音乐的个性推荐已经洞悉了所有单身狗用户的生活常态:
「别总在评论区呆着了,请在下个元年来之前,找到自己的幸福。要不然,狗年一过,你的头衔就会变成:『单身猪』。」
情人节快乐,狗年快乐。

在知乎上,「网易云音乐的歌单推荐算法是怎样的」与「网易云音乐到底好在哪里」这两个问题,分别占据了「网易云音乐」热门话题的第三与第八位。
而很大程度上,第一个问题成就了第二个问题。

或许网易云音乐在知乎上好评一边倒的原因五花八门(有人说雇了大量水军,如果是这样,那应该是笔重金投入。我不会告诉你两个平台的社群重合度很大的),但歌单质量硬,且个性推荐对比国内竞品相对精准,是让一部分用户发展成为网易云音乐死忠粉的关键原因之一。
以及,第一个问题也可以解释,为何你在很多歌的评论区里,都会看到像「日推第一」「日推第二」「日推+FM同时推荐」这类的大量评论。

然而,有人把网易云音乐比作是「独立且小众音乐爱好者的天堂」其实并不十分贴切。将那些被大众忽视的歌重新曝光于你的眼下,很多时候是技术在背后起的作用。
就像你今天下载了一首周杰伦的歌,系统第二天是推给你周杰伦另一首曲风类似的热门歌曲,还是推一首曲风类似的冷门歌曲,更会让你感到新奇?
这个答案有点真相
不过倒是让人有点惊讶,网易云音乐从来没有官方披露过自己的推荐算法与产品应用细节。但这不妨碍大众对其技术与产品融合的过程产生兴趣。
因此,网易云音乐里的算法模型与 AI 应用,基本已经被知乎用户们扒了个底朝天了。
你完全可以在「网易云音乐的歌单推荐算法是怎样的」这个知乎话题里找到非常棒的解答与推测(里面的高赞答案比媒体的报道简直不要清楚太多,讲的明白易懂)。
而我们之所以要拜访网易云音乐的数据挖掘工程师徐家与产品经理沈博文,与其说是揭开算法秘密,不如说是验证此前(包括网络上)的种种猜测,以及帮用户们解答在使用网易云音乐过程中产生的疑惑。
基础算法:人以群分
实际上,网易云音乐个性化推荐的算法与今日头条、B 站还有很多 O2O 电商平台应用的基础推荐算法大同小异。这个得到了徐家的认证,就是我们熟知的那类基础算法:
协同过滤算法
这个算法要归功于亚马逊工程师的「发明」——「一个客户买了这个东西,那么他也可能买另一个东西」。
简单来说,该算法的预测标准取决于「人与人之间相似的消费模式」。譬如「我喜欢这两首歌,而你的歌单里也有这两首歌,所以你歌单里有可能存在其他我喜欢的歌」。
以上的说法只是便于理解。实际上,协同过滤算法其实应该分为两类:「基于用户」与「基于项目(单曲)」。
1、基于用户:我与小明收藏的歌单相似度很高,那么在判断我们口味相似的基础上,可以给小明推荐我歌单里她没收藏过的单曲。

基于用户。图片来源:数据挖掘工人
2、基于项目(单曲):就是将用户对一首歌的偏好作为向量计算单曲之间的相似度,比对相似度后,根据这个用户历史偏好为另一位用户推荐单曲。
举个例子,小歆下载了《勇气》《小情歌》两首单曲,而小宜下载了《勇气》《天黑黑》和《小情歌》,而小艺下载了《勇气》…
那么根据这些用户的历史偏好,网易云音乐可以判断《勇气》与《小情歌》是相似的,喜欢《勇气》的可能也会喜欢《小情歌》,那么可以把《小情歌》推荐给小艺。

基于项目。图片来源:数据挖掘工人
总之,如果你觉得对于「协同过滤」这种算法仍然理解困难,那可以只记住一个词:
人以群分。
在这里要歪个楼:正是这种本质上基于用户偏好相似度的推荐模型,在无形中让用户在听音乐中组成了一个个「彼此聊得来」的社群。
因此,沈博文并没有把「以后可能会发展成全国最大的婚恋交友网站」看作是一个无厘头的笑话。而是认为这种基于音乐喜好的社交趋势,反而比当下的交友平台更靠谱:
「好奇心日报之前曾做过一个调查——『人类找到灵魂伴侣的主要参考标准是什么?』 是音乐品味。」

神经网络模型下的「物以类聚」
可以看到,这种推荐算法绝对缺不了用户历史数据的支撑。在数据量庞大且足够干净的时候,协同过滤算法是非常强大的。
那么反过来想,假如我是一个新用户,或者我使用网易云音乐的频率特别低。也就是说,在数据稀少的情况下,网易云音乐该怎么获知我的口味?
这种冷启动问题,意味着不同算法模型交叉使用的必然性。或许下面的第二大类算法能在一定程度上消除这个障碍。
基于内容的推荐算法。
这是以区分单曲内容实质为核心的推荐方式,就看做是「物以类聚」吧。
全球著名音乐流媒体平台 Spotify 内容推荐模型的建立者之一 Sander Dieleman(现在是 DeepMind 研究科学家),曾在一篇名为《卷积神经网络在音乐推荐里的应用》的博文中具体阐释了使用单一协同过滤算法会存在的误差:
1、由于这种算法除了用户及消费模式信息外,不涉及被推荐单曲本身的任何信息。因此,热门音乐就比冷门音乐更容易得到推荐,因为前者拥有更多的数据。而这种推荐往往是很难让人感到惊喜的。
2、而基于项目(单曲)的协同过滤,也有一个问题,就是相似使用模式下的内容异质。
例如你听了一张新专辑里面全部的歌,但除了主打歌,其他的一些插曲、翻唱曲以及混音曲可能都不是歌手的典型作品,那么协同过滤在这个时候,就会因为这些「噪音」而产生偏差。
当然,它最大的问题便是「没有数据,一切皆失效」。
因此,基于内容的推荐算法更像是对协同过滤算法以上缺陷的一种补充——假如没有大量用户数据,或者想听冷门歌曲,我们就只能从音乐本身寻找答案了。
徐家与沈博文两位专家明确表示,网易云音乐针对这些问题采取了基于内容的复杂算法。但较为遗憾,二位对具体细节并没有进行过多解释。
因此,根据我们的猜测,他们运用的应该与 Spotify、Youtube 等流媒体平台一样的方法——利用深度学习建立基于音频的推荐模型。
首先,如果要对比单曲与单曲之间的内容差异,那么维度就太多了,譬如艺术家及专辑信息、歌词、音乐本身的旋律及节奏、评论区里的「夸夸其谈」、VIP 下载歌曲、付费与否等等元素。
可以想象,这是一个多么庞大的计算量。不过暴力全量计算不失为一种方法……
因此,要通过特征 embedding 和降维方法,把这么多特征映射到低维的隐变量空间里(如同下图)。
可想而知,在这个空间里,每首歌都可以有一个坐标,而坐标数值就是包括音频特征、用户偏好在内的多重编码信息。

那么,假如我们直接预测了一首歌曲在这个低维空间中的准确位置,也就明确了这首歌的表征(包括用户偏好信息)。
这样就能够把它推荐给合适的听众,且并不需要历史使用数据。
因此,掌握了大量歌曲数据源信息与用户行为数据映射出来的隐含特征,再以此建立基于音频特征的神经网络预测模型,用短音频片段训练网络,是很多流媒体正在采取的方式。
(具体方法可以去翻翻 Sander Dieleman 的论文,如果你懂这个,给我们来讲一课!)
当然,在训练网络过程中,工程师门还是会通过「丢弃」(Dropout)等方法来降低过滤模型隐藏表征与音频预测之间的标准差(不能让数据集离散度太高),而这样做主要是为了降低歌曲人气对推荐系统的影响。
没错,这就是你能够收到更加小众歌曲推荐的缘由。

当然,以上无论哪种算法,其实都会基于一定的「相似度」。
譬如网易云音乐也同时应用了机器学习排序模型,这种模型仍然是基于用户行为数据与相似度(也是很普遍的一种模型)。
体现在应用上,通俗来讲,就是你的「每日推荐」歌单里,第一首歌通常是系统认为与你的喜好匹配度最高的一首(很多人常常在评论区喊出的「日推第一」,其意义还是蛮大的)。
而知乎里有大 V 提到的推荐模型「潜在因子矩阵」,徐家则认为已经过时了,「现在用的人已经很少」。
计算方法——我们歌单相似度到底怎么算出来的?
据徐家透露,网易云音乐则主要运用了两种度量方式:
欧式距离与余弦相似度。
CSDN 一位技术专家的博客已经把两者之间的差异解释的非常清晰了(下图):

来自名为Ying的CSDN技术博客
前者是被看作坐标系中的两个点,来计算两点之间的距离。
譬如上图数据 A 和 B 在坐标图中当做点时,两者相似度为两点之间的绝对距离 dist(A,B)。
而后者是看成坐标系中两个向量,来计算两向量之间的夹角。
譬如图中的 cosθ,夹角越小,相似度越高。
你会发现,仍然是在这张图上,如果 B 的位置不变,A 点的位置沿 A 到原点这条线的反方向不断延伸,A 与 B 的余弦夹角就是永远不变的,但两点的绝对距离却发生了变化。
这种差异,导致他们需要被用于不同的数据分析模型。
徐家解释,能够突出数值绝对差异的欧氏距离,在计算歌曲本身相似度时用的比较多。
举个例子,A 歌曲 1 万人喜欢,而 B 歌曲 2 万人喜欢,由于样本量足够大了,可以把所有用户对歌曲的喜好看成一样的强度,那么就可以直接用欧式距离来算。
在欧式距离下,用户对歌曲的偏好都可以被认为是一样的分数,可以简化歌曲相似度的计算。
而余弦相似度更多是从用户偏好方向上区分差异。
譬如网易云音乐可以用该方法,通过用户对内容评分(有下载、收藏、搜索、不感兴趣等不同评分权重)来区分用户兴趣的相似度。

总之,结合了上述算法与计算方式,网易云音乐的个性推荐在大众里的口碑还不错。
但这种「还不错」,如果仅仅依靠技术就能达成,恐怕亚马逊在中国的业务就不会这么糟糕了(我其实在吐槽它的界面)。
坦白讲,再牛逼的算法也有不足。
对于所有音乐产品,用户体验的分值都是由编辑及项目协作、界面设计喜好、音乐版权丰富程度以及音乐偏好预测、技术能力、问题反馈速度共同构成的。
这也是为何有人为网易云音乐的推荐歌单疯狂打 Call,而也有不少人称「听歌比较杂的人可能用网易云音乐真的很心累」。
举个例子,你是一个忠实的欧美音乐圈粉丝,但却在最近偶尔下载了一首中文歌。
那么我可以确定,你第二天的推荐歌单里,一定会有一首中文歌。接下来只能不停地对出现在歌单里的中文歌狂点「不感兴趣」了。
(推荐算法设定了基于不同用户行为的权重,「下载」最高,收藏、搜索、分享其次,此外你也可以点击「不感兴趣」,或许会避开这类歌)

人工不可缺少
除了算法推荐,在很大程度上,一个流媒体平台也一定会承担人工过滤职责,从产品及运营角度确立人工规则,筛除不符合条件的选项。
沈博文告诉我们,他们不只是依赖算法,而是希望通过一些人工的力量,来补偿算法的一些不足。
因此,除了有单独的算法团队,网易云音乐也有一个强大的编辑团队。
一方面,他们帮助在一开始推荐内容上面做一层筛选,找出那些比较优质的内容,保证整一个推荐库的健康。
而另一方面,他们也需要解决算法的一些收敛问题。
「因为如果纯粹依靠算法推荐的话可能会对一些新内容响应较慢,我们也会用一些人工编辑的方式。去寻找出一些可能我们觉得非常优质的内容,然后推荐给大家,」沈博文表示。
此外,即便客服系统在一定程度上依赖AI技术,但由网易云音乐客服部门与技术部门共同组成的「人工反馈小组」,才是让用户对网易云音乐好感up的重要原因。
很多「秒回」的技术解决方案还被用户戏称为「原来网易云音乐的小编真的是活的」。
在平台发展初期,数据量尚不能满足建立推荐算法模型时,就像知乎一位名叫沙克的互联网作者描述的那样:

让单身狗犹如过情人节的“网易云日推”原来是这样生成的相关推荐

  1. 网易云音乐params和encSecKey参数生成代码

    网易云音乐params和encSecKey参数生成代码 不废话,直接上code import requests import json import base64 import random impo ...

  2. 音乐竞品分析:酷狗、QQ音乐、网易云、酷我、汽水音乐

    一.市场趋势         根据<2020年中国音乐产业发展研究报告--数字篇>可知, 随着我国国民经济的持续发展,居民可支配收入稳步上涨,文化娱乐消费在居民日常生活中的重要程度亦相应地 ...

  3. python作业记录--爬虫,网易云音乐热评+词云生成

    import requests import json import re import random from Crypto.Cipher import AES from base64 import ...

  4. python爬取网易云音乐薛之谦歌词数据,生成词云

    老薛最近频频上热搜,因为老薛的歌大部分是自己作词,所以感觉他的歌词和他应该有某种情感表达和联系吧. 于是用python爬了网易云音乐中老薛的歌词数据,并简单用wordcloud写了个词云统计. 难过, ...

  5. 酷狗免费下载歌曲(网易云同样适用)

    打开酷狗音乐-播放歌曲 f12打开网页源码 选择network-media-连续按键f5直到出现mp3链接 打开链接-点击三点-下载

  6. 网易云音乐评论抓取及生成词云

    在csdn首页上偶然看到了这个话题,然而那篇文章并没有分词,而且只有首页的评论,找了相关的资料,都不能直接运行. # -*- coding: utf-8 -*- """ ...

  7. 网易云音乐导出歌单-速食版

    文 | 轩辕御龙 来源:Python 技术「ID: pythonall」 动机是啥 随着之前版权大战的落幕,网易云音乐坐拥最忠实的一批用户,但是却在版权上缺失了一大块,带给用户很不好的使用体验.于是很 ...

  8. 网易云祝福酷狗“狗年快乐”,大文娱之战下的音乐棋子

    前言:近年来,以虾米之死为收官,音乐软件日渐肃杀战争的背后,既是版权争夺战,也是国内以腾讯.网易.阿里巴巴为首的互联网企业在整个大文娱板块的战争.只是在巨头的混战中,似乎没有人关心,从免费到订阅,从百 ...

  9. 网易云短信php接口,网易云音乐简单API

    重要:本文最后更新于2018-01-22 12:55:40,某些文章具有时效性,若有错误或已失效,请在下方留言或联系代码狗. 由于未找到网易云音乐官方公布的API(反正我没找到),这里的API都是通过 ...

最新文章

  1. 源码推荐:collectionView拖拽,仿凤凰FM iOS 局部监听键盘再也不会挡住输入框
  2. you-get 一个下载视频的好工具
  3. SQL Server 自定义快捷键
  4. UNIX再学习 -- 记录锁
  5. Oracle 11g客户端及PLSQL Developer配置|Instant Client Setup-64位|OraClientLite11g_x86
  6. mac os 配置 mysql_基于MAC OS 操作系统安装、配置mysql
  7. 分组框 GroupBox
  8. 几个简单的Linux驱动程序
  9. 图:最新微软框架的现场计分双屏管理系统终于收工,大家请欣赏界面。
  10. 让Latex支持中文
  11. 湖南大学高级软件开发过程
  12. PERT网络分析法(计划评估和审查技术)
  13. CentOS安装Nacos后,输入默认用户名和密码nacos/nacos,提示“用户名或密码错误”
  14. python实时定位查询系统_selenium打开天眼查实现自动搜索查找功能
  15. java类为什么要序列化_Java 中的类为什么要实现序列化呢
  16. Oracle创建用户与授予表空间与权限
  17. Android 图片文件读取
  18. 【前端应该掌握的一些知识点】
  19. android 斜边_Android -- 一个滑动旋转的弧形菜单
  20. (附源码)计算机毕业设计SSM基于框架的旅游订票系统

热门文章

  1. 新生儿取名:撩人于无形的女宝宝名字,任你挑选
  2. 安卓9可用的性能监视器_监视应用程序生态系统的性能和可用性
  3. [电路]5-电压源、电流源的串联和并联
  4. JSD-2204-创建Spring项目-Day19
  5. 【硬核】肝了一个月,Cisco网络工程师知识点总结
  6. JDK8 ThreadLocal 源码解析与最佳实践
  7. java定时器每月月末自动执行
  8. 企业咨询行业拓客的10个经典方法
  9. iOS印象笔记添加到Siri捷径,怎么实现的?
  10. 哈工大计算机网络MOOC作业题解答