Chat-REC: Towards Interactive and Explainable LLMs-Augmented Recommender System

1、动机

推荐系统被应用于推荐服务,提高人们的生活质量,但仍存在一些问题。缺少交互性、可解释性,缺乏反馈机制,以及冷启动和跨域推荐。

Chat-Rec 将用户画像和历史交互转换为 Prompt,有效地学习用户的偏好,不需要训练,完全依赖于上下文学习,有效推理出用户和产品之间之间的联系。

产品之间用户偏好相关联,允许更好的跨域产品推荐。

2、具体框架

用户与物品的历史交互、用户档案、用户查询和对话历史作为输入,并与推荐系统R接口。如果任务被确定为推荐任务,该模块使用 R 来生成一个候选项目集。

传统的推荐系统经过排序产生一个产品候选集,llm根据对候选集中的产品进一步的排序,给出最终更小、更相关的物品集。

chat-rec推荐案例,截图2,左图是引入了用户信息的chat-rec系统,能够根据用户的行为给出相应的推荐理由,右图则没有

3、冷启问题

新产品缺少用户交互,预先用互联网上的信息进行训练的 LLMs 实际上可以作为多视角的知识库,通过llm获取新产品的嵌入表征并存储,提高新产品的展示机会,提供用户更好的展示。

4、跨域推荐

预先用互联网上的信息进行训练的 LLMs 实际上可以作为多视角的知识库,不同产品会有一些共性,llm可以通过对某一产品的喜好,推演到其他产品的上面。

5、实验

数据集是 MovieLens 100K,随机筛选了 200 个用户组成数据集

Chat-Rec 可以根据用户偏好进一步优化推荐系统推荐的候选集

Top-k推荐任务评估对比

zero-shot任务评估对比

不同的temperature下,随机给出候选和经过排序给出候选差异很大。先经过推荐系统排序筛选候选很重要。

6、参考文献

【1】https://arxiv.org/pdf/2303.14524.pdf

【2】Chat-REC: 当推荐系统遇上 ChatGPT, 会发生什么奇妙反应? - 知乎

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

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

相关文章

【漏洞复现】用友NC cloud importhttpscer 存在任意文件上传

0x01 阅读须知 “如棠安全的技术文章仅供参考,此文所提供的信息只为网络安全人员对自己所负责的网站、服务器等(包括但不限于)进行检测或维护参考,未经授权请勿利用文章中的技术资料对任何计算机系统进行入侵操作。利用此文所提供…

STM32L4R9 的 QuadSPI Flash 通讯速率不理想

1. 引言 客户反应 STM32L4R9 同 QSPI Flash 通讯,测出来的读取速率为 10MB/s, 和理论值相差较大。 2. 问题分析 按照客户的时钟配置和 STM32L4R9 的数据手册中的数据,OSPI 读数速率为 10MB/s 肯定存在问题。同时我们也可以在 AN4760 应用手…

python 字符串补齐

参考文献 https://blog.csdn.net/ViatorSun/article/details/130424704 今天遇到一个格式化字符串的问题 "123".ljust(8,"0")"123".rjust(8,"0")

苍穹外卖07(缓存菜品,SpringCache,缓存套餐,添加购物车菜品和套餐多下单,查看购物车,清除购物车,删除购物车中一个商品)

目录 一、缓存菜品 1 问题说明 2 实现思路 3 代码开发:修改DishServiceImpl 4 功能测试 二、SpringCache 1. 介绍 2. 使用语法 1 起步依赖 2 使用要求 3 常用注解 4 SpEL表达式(了解备用) 5 步骤小结 3.入门案例 1 准备环境 2 使用入门 1 引导类上加…

b站评论词频统计绘制词云图

一、评论爬取 在笔者之前的文章中,已经专门介绍了b站评论的爬取(传送门),这里只对b站评论的文本数据做展示。如下图所示: 二、分词、去停用词、词频统计 Python中的Jieba分词作为应用广泛的分词工具之一,其…

【面试经典150 | 动态规划】最长回文子串

文章目录 写在前面Tag题目来源解题方法方法一:动态规划 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法,两到三天更新一篇文章,欢迎催更…… 专栏内容以分析题目为主,并附带一些对于本题涉及到的数据结构等内容进行…

【OJ】动规练习六

个人主页 : zxctscl 如有转载请先通知 题目 1. 413. 等差数列划分1.1 分析1.2 代码 2. 978. 最长湍流子数组2.1 分析2.2 代码 3. 139. 单词拆分3.1 分析3.2 代码 1. 413. 等差数列划分 1.1 分析 一、题目解析: 至少有三个元素才能构成等差数列&#xff…

【开发环境】Mac 安装 Visual Studio Code ( VSCode 简介 | 下载 VSCode | 安装 VSCode | 安装中文语言包 )

文章目录 一、Visual Studio Code 简介二、MAC 安装 Visual Studio Code1、下载 Visual Studio Code2、安装 Visual Studio Code3、安装中文语言包4、编辑 html 并运行 一、Visual Studio Code 简介 Visual Studio Code 简称 VSCode , 是 微软 开发的一款 轻量级 / 跨平台 的代…

前视声呐目标识别定位(五)-代码解析之修改声呐参数

前视声呐目标识别定位(一)-基础知识 前视声呐目标识别定位(二)-目标识别定位模块 前视声呐目标识别定位(三)-部署至机器人 前视声呐目标识别定位(四)-代码解析之启动识别模块 …

arm裸机-1、定时器pwm

时钟配置 我们使用s3c2440,主频12M,查看用户手册 通过锁相环抬升到400MHZ,分成三条通路,通过HHDIVN和PDIVN配置频率比,这个频率比配置手册已经给出。 配置MPLL主频400Mhz, 通过这个公式算出MPLL s、p、m都…

Redis从入门到精通(四)Redis实战(二)商户查询缓存

↑↑↑请在文章头部下载测试项目原代码↑↑↑ 文章目录 前言4.2 商户查询缓存4.2.1 缓存介绍4.2.2 查询商户信息的传统做法4.2.2.1 接口文档4.2.2.2 代码实现4.2.2.3 功能测试 4.2.3 查询商户信息添加Redis缓存4.2.3.1 逻辑分析4.2.3.2 代码实现4.2.3.3 功能测试 4.2.3 数据一致…

动力云客-B站(第一天)

一 项目技术选型及开发工具 前后端分离的项目(前端项目 后端项目) 前端:Html、CSS、JavaScript、Vue、Axios、Element Plus后端:Spring Boot、Spring Security、MyBatis、MySQL、Redis 相关组件:HiKariCP&#x…

【C++进阶】带你手撕红黑树(红与黑的爱恨厮杀)

🪐🪐🪐欢迎来到程序员餐厅💫💫💫 主厨:邪王真眼 主厨的主页:Chef‘s blog 所属专栏:c大冒险 总有光环在陨落,总有新星在闪烁 引言: 之前我们…

K8S- Deployment 的滚动更新 Rolling Update

滚动更新 这里的更新指的不是更新deployment 本身的属性(label/ replicas)等, 而是更新POD 的container 的版本 更新方法通常有两种 是直接update deployment配置, 注意只有update了template中的内容(与container相关) 才会触发更新用kubectl set ima…

【蓝桥杯】GCD与LCM

一.概述 最大公约数(GCD)和最小公倍数(Least Common Multiple,LCM) 在C中,可以使用 std::__gcd(a, b)来计算最大公约数 1.欧几里德算法/辗转相除法 int gcd(int a,int b){return b?gcd(b, a%b):a; } 2…

CATIA软件 焊点坐标(BiW Welding SpotPoint)导出txt文本的操作方法

通常我们客户给的工件是带焊点球的形式,且可导出焊点坐标。如下图所示的焊点位置标识及坐标,即是CATIA中Automotive BiW Fastening模块下的BiW Welding SpotPoint焊点定义。 遇到这样的形式,要导出焊点坐标txt文本,可按如下图片找…

ssm023实验室耗材管理系统设计与实现+jsp

实验室耗材管理系统的设计与实现 摘 要 互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播,搭配信息管理工具可以很好地为人们提供服务。针对实验室耗材信息管理混乱&#xff…

深入浅出 -- 系统架构之单体架构和微服务架构的区别

在软件开发中,架构设计是非常重要的一环。架构设计不仅决定了软件系统的性能、可维护性和扩展性,还直接关系到开发成本和项目进度。目前,主流的架构设计模式有两种,一种是单体架构,另一种是微服务架构。本文将详细介绍…

【C语言】从零开始:用C语言实现顺序表

欢迎来CILMY23的博客 本篇主题为 从零开始:用C语言实现顺序表 个人主页:CILMY23-CSDN博客 C语言专栏: http://t.csdnimg.cn/hQ5a9 Python系列专栏:http://t.csdnimg.cn/HqYo8 上一篇C语言博客: http://t.csdnimg.…

pwn学习笔记(7)--堆相关源码

相关源码: 1. chunk 相关源码: ​ 对于用户来说,只需要确保malloc()函数返回的内存不会发生溢出,并且在不用的时候使用free() 函数将其释放,以后也不再做任何操作即可。而对于glibc来说’它要在用户第一次调用malloc…