深度语义模型在推荐系统中的应用实战(youtube dnn)--part2

part2背景:众所周知,数据是最终效果的天花板,而不同model在同一份数据上只不过是代表了不同逼近天花板的程度,有鉴于此,本小节也分两大块展开,将重点带给大家样本,特征的一些实战知识技巧以及youtube dnn model一些重要参数设置与注意事项。

一。图1是训练数据以及测试数据获取的整体流程,我一直以为在不同的业务线想要把model训练好,首先要了解业务场景,其次要了解原始log以及一些关键信息的存储获取方式。只有这样才能让数据为自己所用,才能比较随心的使用各种样本处理技巧,特征处理技巧。整体流程上输入源分为三大块feed 点展日志,小时级别存储在hdfs,user profile日志天级别存储在hdfs,格式是pb,item info存储与hbase。整体步骤主要经过了样本筛选,用户侧特征筛选与转换,item侧特征筛选与格式化,label筛选,以及user 侧或者是label侧的样本均衡【我都试验过后根据试验效果保留了裁剪版本的label均衡】,之后将得到的instance分成两部分train与test data。供每天的model train与model test使用。下面将每一部分拆开具体讲解一下。

图1 train instance get main flow

样本选择:无论是recall model还是rank model的模型构建过程中,样本选择都是非常重要的,我这里主要是只筛选出了近3天的feed流下用户的真实点击短视频数据,不需要用户的展现,不需要用户的被动点击(watch time < thr以及一些产品形式下的自动播放),不需要图文的点击。重点是得到这部分用户。根据这些用户的历史点击的item,只要这些item不过期每个item都会产出一条样本。举个例子,用户的点击是1,2,3,4,5,6,7.那么根据1 我们能产出一条训练数据,只不过这个时候在历史点击特征下是2,3,4.还可以产出一条label是2 的训练数据,历史点击这一维度的特征是3,4,5.您可以根据自己的情况改变长度。这是我自己产出样本的一个方法,我猜youtube 也是这么产出的。

特征筛选:得到了哪部分用户是我们是需要构建训练数据需要的之后,我们开始进行特征的组织,先说一下重点,也就是用户侧特征的组织,根据原论文(part1 的引用1)的推荐,像用户的点击历史,用户的搜索历史,用户的一些基础信息的profile,比如年龄,性别等等这些之外,用户的地理信息,城市,省份等等,我自己又新加了一些新的特征,像字符串类型的用户的星座,数字类型的比如观看过多少视频,观看总时长等等。数字类型的特征一定要尽量作细统计分布之后的归一化处理在我个人多个模型的实战之中都起到非常重要的作用。如果您看了这篇文章,也在做您自己的model,没必要完全按我提到的上述特征,因为特征的抽取需要符合自己的产品,以及自己的产品的数据建设,没有规定的选择方式,不要拘泥于别人的形式,在覆盖率准确率都能保证的情况下,可以大胆的使用,尤其是深度模型里面对string的极大包容(hash之后的embeding)给了我们更宽广的处理空间,当然用户侧还有一些特征也是我们这里同学画像做的比如用户喜欢的item category等等标签,有就用。没有也没关系。item侧特征的组织在这里只有一个就是item score,相当于是click time与item产出时间的一个delta time的衰减得分。关于特征筛选最后说一句,我看过很多数据挖掘,特征筛选处理的文章与书,但是这些不足以让你成为一个好的构建model的工程师,一定要有自己对于业务的理解,数据的判断,最重要的加上大量的实践。

label筛选与编号:label 编号大家可以理解,以为你写itemid当label机器是识别不了的必须要转换成数字比如0,1,2...然后记录好这个对应关系。这样导出item侧特征的时候,能对应好itemid 与itemvector,如果这个对应关系错乱了,那么就后果不堪设想。为什么这里还有label筛选,这也和我们自己的产品形态有关系,也许您的产品就不需要,因为我们这里每天进入展现索引的不是历史上的全量itemid,是筛选了一部分,加上淘汰一些脏乱差和过期等等。这么说吧相当于每天早晨重新建一遍索引写一下搜索引擎,您可以理解成ES,当然我们用的不是es,用的是自有研发的一套。这样很多用户历史点击序列的里的item已经过期了也就不用在根据这些item去产出无用的样本。

样本均衡:样本均衡在大规模的分类问题上是极其有必要的,避免样本的不均衡造成model学习的不充分。样本均衡的方式方法两种:一,改变model里对不同label的权重,例如加一些词典来控制。二:改变样本的分布。第二种相对来说灵活可以试验多种方案,随意改变,落地成本低。所以我在实战中采用了第二种方法,分别尝试了对用户以及label做均衡。具体就是统计一下一共有多少个label或者user,限定一个具体num 让 label数目*num = fix_train_data 数目,这个fix train data数目是你自己理想的训练数目,因为说过这个model得在gpu训练特别的样本数量的话会慢。根据限定的具体的num数目,label多于这个数目的就随机裁剪掉,低于这个数目的就补充到这个数目。最后试验中发现对label做均衡效果好一些。我自己采用了label均衡。

好了,关于训练样本产出方面想要说的差不多说完了。来看model参数方面。

二:训练中model 参数的几点说明:

其实文本类 nn model在训练过程中所选择的参数也就那么一些个,常训练的话大差不差都会有感觉,但是我下面想说的几个综合反映一个思想就是不要迷信别人是怎么做的要有自己的思路。

激活函数:我在看paper[part1 引用1]时候paper使用的激活函数是relu,所以我在trainmodel 开始的几天里一直坚定不移的使用relu,但是搭起tf serving,用脚本发请求发现大量user embedding输出为0向量,观察tensorboard发现在最后一个隐层上0激活值占比0.9+,那就没法玩了,因为这个我调整了很多地方,都没能解决,因为关于这个youtube dnn落地文章在网上不仅仅是少,几乎没看到,网上的大多在翻译论文,没啥实战参考价值。最后调整了一下激活函数为sigmod好了。relu函数确实比sigmod在梯度弥散方面要表现的好。但是这里我猜wx+b好多负数值,所以不能选relu。

负采样函数:因为这里的负采样函数是两层采样,根据paper[part1,引用2]文章所说,第一层采用数目在总label数目的%1-%10为合适,亲测有效果,关键是第二层采样数目,试过为第一层的二分之一,四分之一,。。等等多轮尝试,发现效果不如第二层数目和第一层数目几乎一样好。这个效果是一看tensor board,交叉熵损失函数收敛曲线。二看,训练完model 搭起tf serving,随意抽取n个用户进行向量召回topkl的结果的重合度。重合度越小越好。

该model的离线效果分析也是分为两部分1.model在测试集上的top50预测准确率长期稳定在0.7-0.8之间。在百万级别的分类问题上,这个数字相当可以。2.model在随机抽取10个用户,top100向量召回的结果总itemid,长期稳定在990+,极少重合。有了离线的结果分析,也给在线尝试带来了一些信心,但是差点遭遇职业生涯的第一次惨败,预知详细故事以及最后如何转败为胜的。请看下回分解。

好了第二部分的内容也基本介绍完了。下面进行第三部分的介绍。online 部分的应用与收益分析。

原创文章如需转载注明出处。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容