不懂推荐算法也能设计推荐系统

2024-09-09 18:08
文章标签 算法 设计 系统 推荐

本文主要是介绍不懂推荐算法也能设计推荐系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。

不懂推荐算法也能设计推荐系统?

相信很多新手产品,看到算法二字,多是懵圈的。

什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。

但,不了解推荐算法,就无法做推荐系统了吗?其实,产品人员可以从产品侧挖掘自己的长处。

下面,以商业化应用推荐为例,讨论如何在不熟悉推荐算法的前提下设计推荐系统。

 

01 解决什么问题

收入:推荐用户感兴趣的应用,提高收入。

改善用户体验:对于用户不感兴趣的应用,少推荐,减少整体的广告显示,提升用户体验(毕竟,多数情况下,商业化与体验是矛盾的)。

 

02 设定目标

这是比较难的。需要了解当前的推荐策略 与 优化后的策略,才能制定出来。要么你熟悉推荐算法,要么知晓行业数据。建议是:如果没有明确的依据,不要拍脑袋。

 

03 有什么数据

用户画像,是一个谈到烂的话题。但小体量的公司很难把用户画像落地,因为需求是简单的:根据用户画像,用户的喜欢做……但在实际执行中,很难建立一个数据模型处理万千的数据并应用到推荐场景当中。

下面讨论数据情况,有哪些维度的数据,直接决定数据模型。

 

1. 基础数据

无论贵公司是以APK还是SDK的方式,用户手机安装了什么应用,均可以拿到。具体数据如下:

 

2. 基础数据的推导

根据基础数据,我们可以推导出应用卸载列表。

用户卸载列表:指用户点击安装后,又卸载的应用。用相临两周的应用列表,做差,即可得到。如下图所示,相对于本周数据,上周缺少了百度地图与饿了么两个应用。

不懂推荐算法也能设计推荐系统?

 

3. 不喜欢应用列表

是指,推荐给用户的应用,有效展示后,用户不点击的应用列表。

 

04 高阶数据

如果可以获取用户使用应用的详情,那做应用推荐时,准确度可大幅提升。但普通应用获取不到此类数据,所以本篇不作讨论。

 

05 推荐策略

推荐应用给用户,可以有多种推荐策略。如:

  • 已安装类别中,推荐额外应用:如用户安装了QQ音乐,可以推荐网易云音乐。
  • 推荐缺少类别的应用:用户缺少健身类的应用,推荐KEEP。

下面,我们以“推荐缺少类别的应用”为例:

 

1. 先上整体流程图

不懂推荐算法也能设计推荐系统?

第一步:获取用户本地应用,即用户当前时间段安装的应用。建议以为统计周期。

第二步:对用户本地应用按类别整理。示例数据中,用户有“系统工具,导航”这两类数据。但缺少“音乐,旅游”等类别的应用。那么每个分类的排名是如何得来的呢?

不懂推荐算法也能设计推荐系统?

衡量一个分类的排名,涉及到多个因素。我们暂时用最简单的,推荐成功率来计算。即:以往的数据中,每个类别推荐成功了多少个应用/总的推荐数。

各位读者实际的项目中,要根据自己的业务特点,来计算排名。

第三步:获取第一个缺失分类及所包含的应用。在步骤2中,排名第1,第2的类别已有,下一个类别为音乐,即为用户缺失的类别中,最为靠前的。如上图红色字所示。

第四步:获取该类别的第一个应用。每个类别可能有多个应用。应用间的排名,也可暂用推荐成功率来计算。如下图所示,在缺少的音乐排名中,QQ音乐排名第一位。我们选出该应用,优先推荐。

第五步:将步骤4中的应用,按不喜欢名单过滤。如上图,如果用户不喜欢QQ音乐,则按照顺序,向其推荐 网易音乐。

最后,统计是否已经达到需要的广告数量。如果没有达到,则继续在该类别中取下一个应用。如果该类别已经取完,则依次获取下一个类别中的应用。

不懂推荐算法也能设计推荐系统?

第六步:保底推荐。最后托底的推荐策略,防止所有的应用遍历一遍广告数量还是不够的情况。

这篇关于不懂推荐算法也能设计推荐系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1151899

相关文章

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

Qt QCustomPlot库简介(最新推荐)

《QtQCustomPlot库简介(最新推荐)》QCustomPlot是一款基于Qt的高性能C++绘图库,专为二维数据可视化设计,它具有轻量级、实时处理百万级数据和多图层支持等特点,适用于科学计算、... 目录核心特性概览核心组件解析1.绘图核心 (QCustomPlot类)2.数据容器 (QCPDataC

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空