如何系统性的学习推荐系统?

推荐一本适合推荐系统、计算广告、个性化搜索领域的从业人员阅读的书:《互联网大厂推荐算法实战》。快手公司算法专家10余年的实战经验总结。涵盖一线互联网公司当前采用的主流推荐算法,凸显可用性、实用性提供从算法基本原理,到技术框架再到核心源码的解决方案。

本书是一本讲述推荐算法、推荐模型的书。本书总计10章,内容涵盖了推荐系统的基础知识、推荐系统中的特征工程、推荐系统中的Embedding、推荐系统的各组成模块(包括召回、粗排、精排与重排)所使用的算法技术、推荐算法实践中经常会遇到 的难题以及应对之道(其中涉及多任务推荐、多场景推荐、新用户冷启动、新物料冷启动、评估模型效果、定位并解决问题等),最后还用一章的篇幅介绍了推荐算法工程师在工作、学习、面试时应该采取的做法。

推荐理由:

本书所讲的都是各互联网大厂当下主流的推荐算法。本书不会讲述协调过滤、矩阵分解这 类“经典但过时”的算法,尽管它们当下仍可能有用武之地,但绝非互联网大厂的主力算 法,也不是面试时的考察重点。另外,针对一些著名的前沿算法,由于其实现相当复杂, 复现效果也比较有争议,且不是业界主流算法,因此本书也没有在它们身上浪费笔墨。

■本书除了讲解最基本的算法原理,还聚焦于算法工程师的工作实际,关注他们日常遇到 的实际难题。比如,新用户与新物料怎么冷启动?如何打开模型的黑盒,以排查问题或 找到下一步升级改进的方向?线下AUC 涨了,但是线上AB 实验的指标却不涨!这到底 是什么原因造成的? ……

■由于算法工程师也属于广义上的程序员,所以源代码才是最清晰直接的说明文档。为此, 本书针对核心算法都提供了相应的源代码。同时,限于篇幅,书中仅对核心代码进行了 展示,而且给出了相应的注释,以帮助读者彻底理解算法的重要细节。

本书特点:

本书将重心放在了帮助读者梳理算法的发展脉 络方面,指导读者由“术”入“道”,达到“举一反三”的目的。举例如下。

■本书梳理了推荐算法有别于普通机器学习算法的特殊性在哪里。充分认识这一特殊性, 是正确、深刻理解推荐算法的前提,否则外行将无法理解很多推荐算法的精髓。

■Embedding 是深度学习推荐算法的基石,本书用“无中生有”来形容这一技术。本书由 评分卡自然推导出 Embedding, 指出引入 Embedding 是推荐系统增强扩展性的必然结果。

■本书提出了理解深度学习推荐算法的5个维度,可帮助读者加深对推荐算法的理解。

本书为所有向量化召回算法提炼出统一的模型框架,以帮助读者充分理解向量化召回算 法的本质。借助这个框架,读者可以从不同算法中各取所长,构建出适合自己业务场景 的向量化召回算法。

■双塔模型是大厂进行召回、粗排的不二主力。本书指出“改进双塔模型的重点在于减少 信息在塔内流动时的损失”,并总结出了改进双塔模型的4条道路。

■元学习可以助力冷启动问题。但是元学习的经典算法在应用于推荐系统时,必须加以改 造,本书梳理出了三大改造方向。

■对比学习在形式上与向量化召回很相似,因此有很多文章“挂羊头卖狗肉”,将普通的向 量化召回包装成时髦的对比学习来蹭热度。本书辨析了这两个技术的异同,并指出对比 学习应用于推荐系统的本质在于“纠偏”。

《互联网大厂推荐算法实战》目录

第 1章 推荐系统简介 1

1.1 推荐系统的意义 2

1.2 推荐系统是如何运行的 3

1.3 推荐系统架构 5

1.3.1 功能架构 5

1.3.2 数据架构 8

1.4 推广搜的区别与联系 10

1.4.1 三驾马车的相同点 10

1.4.2 推荐与搜索 11

1.4.3 推搜与广告 12

1.5 小结 12

第 2章 推荐系统中的特征工程 14

2.1 批判“特征工程过时”的错误论调 15

2.2 特征提取 16

2.2.1 物料画像 16

2.2.2 用户画像 18

2.2.3 交叉特征 21

2.2.4 偏差特征 22

2.3 数值特征的处理 25

2.3.1 处理缺失值 25

2.3.2 标准化 25

2.3.3 数据平滑与消偏 26

2.3.4 分桶离散化 27

2.4 类别特征的处理 28

2.4.1 类别特征更受欢迎 28

2.4.2 类别特征享受VIP服务 29

2.4.3 映射 30

2.4.4 特征哈希 31

2.5 小结 32

第3章 推荐系统中的Embedding 33

3.1 无中生有:推荐算法中的Embedding 33

3.1.1 传统推荐算法:博闻强识 33

3.1.2 推荐算法的刚需:扩展性 35

3.1.3 深度学习的核心思想:无中生有的Embedding 36

3.1.4 Embedding的实现细节 37

3.2 共享Embedding还是独占Embedding 42

3.2.1 共享Embedding 42

3.2.2 独占Embedding 43

3.3 Parameter Server:推荐算法的训练加速器 46

3.3.1 传统分布式计算的不足 46

3.3.2 基于PS的分布式训练范式 47

3.3.3 PS中的并行策略 49

3.3.4 基于ps-lite实现分布式算法 51

3.3.5 更先进的PS 57

3.4 小结 60

第4章 精排 61

4.1 推荐算法的5个维度 61

4.2 交叉结构 62

4.2.1 FTRL:传统时代的记忆大师 62

4.2.2 FM:半只脚迈入DNN的门槛 69

4.2.3 Wide & Deep:兼顾记忆与扩展 71

4.2.4 DeepFM:融合二阶交叉 74

4.2.5 DCN:不再执着于DNN 76

4.2.6 AutoInt:变形金刚做交叉 79

4.3 用户行为序列建模 86

4.3.1 行为序列信息的构成 86

4.3.2 简单Pooling 86

4.3.3 用户建模要“千物千面” 87

4.3.4 建模序列内的依赖关系 89

4.3.5 多多益善:建模长序列 91

4.4 小结 96

第5章 召回 97

5.1 传统召回算法 97

5.1.1 基于物料属性的倒排索引 98

5.1.2 基于统计的协同过滤算法 99

5.1.3 矩阵分解算法 99

5.1.4 如何合并多路召回 100

5.2 向量化召回统一建模框架 101

5.2.1 如何定义正样本 102

5.2.2 重点关注负样本 103

5.2.3 解耦生成Embedding 105

5.2.4 如何定义优化目标 106

5.3 借助Word2Vec 111

5.3.1 最简单的Item2Vec 112

5.3.2 Airbnb召回算法 116

5.3.3 阿里巴巴的EGES召回 118

5.4 “瑞士军刀”FM的召回功能 120

5.4.1 打压热门物料 121

5.4.2 增广Embedding 122

5.5 大厂主力:双塔模型 124

5.5.1 不同场景下的正样本 124

5.5.2 简化负采样 124

5.5.3 双塔结构特点 126

5.5.4 Sampled Softmax Loss的技巧 127

5.5.5 双塔模型实现举例 129

5.6 邻里互助:GCN召回 131

5.6.1 GCN基础 131

5.6.2 PinSage:大规模图卷积的经典案例 134

5.6.3 异构图上的GCN 142

5.7 小结 143

第6章 粗排与重排 145

6.1 粗排 146

6.1.1 模型:双塔仍然是主力 146

6.1.2 目标:拜精排为师 154

6.1.3 数据:纠正曝光偏差 158

6.1.4 模型:轻量级全连接 159

6.2 重排 161

6.2.1 基于启发式规则 162

6.2.2 基于行列式点过程 165

6.2.3 基于上下文感知的排序学习 174

6.3 小结 180

第7章 多任务与多场景 181

7.1 多任务推荐 181

7.1.1 多任务建模的误区 182

7.1.2 并发建模 182

7.1.3 串行建模 193

7.1.4 多个损失的融合 202

7.1.5 多个打分的融合 206

7.2 多场景推荐 209

7.2.1 特征位置 210

7.2.2 模型结构 211

7.2.3 模型参数 215

7.3 小结 217

第8章 冷启动 219

8.1 Bandit算法 219

8.1.1 多臂老虎机问题 220

8.1.2 Epsilon Greedy 221

8.1.3 UCB 222

8.1.4 概率匹配 223

8.1.5 Bayesian Bandit 223

8.1.6 上下文Bandit 225

8.2 元学习 228

8.2.1 什么是元学习 228

8.2.2 什么是MAML 230

8.2.3 MAML针对推荐场景的改造 233

8.2.4 Meta-Embedding 236

8.3 对比学习 242

8.3.1 对比学习简介 242

8.3.2 对比学习在推荐系统中的作用与使用方式 244

8.3.3 辨析对比学习与向量化召回 246

8.3.4 纠偏长尾物料的实践 247

8.3.5 纠偏小众用户的实践 249

8.4 其他算法 251

8.4.1 迁移学习 251

8.4.2 预测物料消费指标 252

8.4.3 以群体代替个体 253

8.4.4 借鉴多场景推荐 254

8.5 小结 255

第9章 评估与调试 256

9.1 离线评估 256

9.1.1 评估排序算法 257

9.1.2 评估召回算法 261

9.1.3 人工评测 266

9.1.4 持续评估 267

9.2 在线评估:A/B实验 267

9.2.1 线上:流量划分 268

9.2.2 线下:统计分析 273

9.3 打开模型的黑盒 276

9.3.1 外部观察 276

9.3.2 内部剖析 277

9.4 线下涨了,线上没效果 280

9.4.1 特征穿越 280

9.4.2 老汤模型 282

9.4.3 冰山:系统的内在缺陷 284

9.4.4 链路一致性问题 285

9.5 小结 286

第 10章 推荐算法工程师的自我修养 287

10.1 工作 287

10.1.1 重视代码的规范性 287

10.1.2 重视离线评测 288

10.1.3 重视使用工具 289

10.2 学习 290

10.2.1 坚持问题导向 290

10.2.2 重在举一反三 291

10.2.3 敢于怀疑 292

10.2.4 落实代码细节 293

10.3 面试 293

10.3.1 社招 294

10.3.2 校招 296

10.4 小结 297

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/420565.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

python语言1

一、pytho中的注释 1.1注释的理解 程序员在代码中对代码功能解释说明的标注性文字可以提高代码的可读性注释的内容将被python解释器忽略,不被计算机执行 1.2注释的分类 注释分为:单行注释、多行注释、中文声明注释 (1)单行注…

java项目打包运行报异常:xxxxx-1.0-SNAPSHOT.jar中没有主清单属性

pom.xml中加入这段话即可 <build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><version>2.4.4</version><executions><execution><…

雨云:为你拨开云雾见青天

一、雨云品牌概览 雨云&#xff0c;这名字一听就让人联想到蓝天白云&#xff0c;清爽自然。那么&#xff0c;这个品牌是否真的如其名&#xff0c;能为我们这些在数字世界中漂泊的旅人提供一片宁静、稳定的“云”呢&#xff1f;接下来&#xff0c;让我们深入了解雨云的资质、能…

【Micropython教程】I2C的使用

文章目录 前言一、I2C的使用1.1 分析一种情况1.2 初始化I2C总线1.3 扫描可用的I2C设备1.4 向指定地址写入数据1.5 读取指定地址的数据1.6 关闭I2C总线 二、示例代码总结 前言 MicroPython 是一种精简的 Python 实现&#xff0c;旨在运行在微控制器和嵌入式系统上。在嵌入式开发…

AVL 树

AVL树的概念 二叉搜索树虽可以缩短查找的效率&#xff0c;但如果数据有序或接近有序二叉搜索树将退化为单支树&#xff0c;查找元素相当于在顺序表中搜索元素&#xff0c;效率低下。因此&#xff0c;两位俄罗斯的数学家G.M.Adelson-Velskii和E.M.Landis在1962年 发明了一种解决…

vue3的router

需求 路由组件一般放在&#xff0c;pages或views文件夹, 一般组件通常放在component文件夹 路由的2中写法 子路由 其实就是在News组件里面&#xff0c;再定义一个router-view组件 他的子组件&#xff0c;机会渲染在router-view区域 路由传参 <RouterLink :to"/news…

腾讯云最新活动_腾讯云促销优惠_代金券-腾讯云官网入口

腾讯云服务器多少钱一年&#xff1f;62元一年起&#xff0c;2核2G3M配置&#xff0c;腾讯云2核4G5M轻量应用服务器218元一年、756元3年&#xff0c;4核16G12M服务器32元1个月、312元一年&#xff0c;8核32G22M服务器115元1个月、345元3个月&#xff0c;腾讯云服务器网txyfwq.co…

xsslabs第七关

源码 <!DOCTYPE html><!--STATUS OK--><html> <head> <meta http-equiv"content-type" content"text/html;charsetutf-8"> <script> window.alert function() { confirm("完成的不错&#xff01;"…

《2023年勒索软件攻击态势报告》

获取方式&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1zd-yVsuGwJADyyGNFR_TIQ?pwd2lo0 提取码&#xff1a;2lo0

游戏空间划分技术

一、 前言 空间划分算法有很多&#xff0c;比如均匀网格&#xff0c;四/八叉树&#xff0c;k-d树&#xff0c;Bsp树&#xff0c;每一种算法都有自己的优缺点&#xff0c;我们需要从理论上理解这些算法&#xff0c;然后在实际项目中进行灵活的运用。 游戏中经常使用空间划分算…

k8s二进制部署的搭建

1.1 常见k8s安装部署方式 ●Minikube Minikube是一个工具&#xff0c;可以在本地快速运行一个单节点微型K8S&#xff0c;仅用于学习、预览K8S的一些特性使用。 部署地址&#xff1a;Install Tools | Kubernetes ●Kubeadm Kubeadm也是一个工具&#xff0c;提供kubeadm init…

【前端素材】推荐优质后台管理系统网页Hyper平台模板(附源码)

一、需求分析 1、系统定义 后台管理系统是一种用于管理和控制网站、应用程序或系统的管理界面。它通常被设计用来让网站或应用程序的管理员或运营人员管理内容、用户、数据以及其他相关功能。后台管理系统是一种用于管理网站、应用程序或系统的工具&#xff0c;通常由管理员使…

Charles抓包 - 安装、激活、证书配置

最近刚好又遇到了抓包的需求&#xff0c;之前一直使用 Fiddler 抓包&#xff0c;这几年一直听大家都在用 Charles 抓包&#xff0c;正好一起了解下&#xff08;一般建议掌握一种抓包方式即可&#xff0c;都可以解决同种需求场景&#xff09; 抓包 Fiddler抓包 Charles 下载、安…

深度解读篇章:剖析构建互联网大厦的基石——TCP/IP协议全貌

&#x1f440;&#x1f440;&#x1f440; 引言 今天&#xff0c;我们一同揭幕的是驱动全球互联网脉搏跳动的核心机密——TCP/IP协议体系。没有它&#xff0c;就不会有现今这般高效便捷的网络生活体验&#xff0c;无论在线教育、远程办公&#xff0c;抑或是电子商务、社交媒体…

强大而灵活的python装饰器

装饰器&#xff08;Decorators&#xff09; 一、概述 在Python中&#xff0c;装饰器是一种特殊类型的函数&#xff0c;它允许我们修改或增强其他函数的功能&#xff0c;而无需修改其源代码。装饰器在函数定义之后立即调用&#xff0c;并以函数对象作为参数。装饰器返回一个新…

Docker容器与虚拟化技术:OpenEuler 部署 docker容器应用

目录 一、实验 1.环境 2.OpenEuler 安装 docker 2.镜像加速 3.docker部署LAMP 二、安装docker报错 2.docker如何快速删除容器与镜像 3.docker创建mysql容器失败 4.docker创建apache容器失败 5.docker创建php-fpm容器失败 6. 80端口与php访问失败 7.httpd容器进入不…

【刷题】Leetcode 1609.奇偶树

Leetcode 1609.奇偶树 题目描述广度优先搜索&#xff08;BFS&#xff09;深度优先算法&#xff08;DFS&#xff09; 思路一&#xff08;BFS&#xff09;思路二&#xff08;DFS&#xff09;Thanks♪(&#xff65;ω&#xff65;)&#xff89;谢谢阅读&#xff01;&#xff01;&a…

【k8s管理--Helm包管理器】

1、Helm的概念 Kubernetes包管器 Helm是查找、分享和使用软件构件Kubernetes的最优方式。 Helm管理名为chart的Kubernetes包的工具。Helm可以做以下的事情&#xff1a; 从头开始创建新的chat将chart打包成归档tgz)文件与存储chat的仓库进行交互在现有的Kubernetes集群中安装和…

【数据库管理系统】Mysql 8.0.36入门级安装

下载地址 官方网址&#xff1a;MySQL 注意事项 建议不要安装最新版本&#xff0c;一般找mysql5.0或mysql8.0系列版本即可&#xff1b;mysq1官网有.zip和.msi两种安装形式&#xff1b;zip是压缩包&#xff0c;直接解压缩以后使用的&#xff0c;需要自己配置各种东西&#xff…

模型优化_如何提高网络/模型的泛化能力?(全面)

目录 1. 以数据为中心的泛化方法 1.1 使用更多数据 1.2 做好数据预处理 特征工程 1.3 数据增强 1.4 调整数据分布 2. 以模型为中心的泛化方法 2.1 使用更大批次 超参数调优 2.2 调整目标函数 2.3 调整网络结构 2.4 屏蔽网络节点 2.5 权值正则化 2.6 偏差-方差权衡…