APP下载

融合协同过滤的CatBoost推荐算法

2021-09-28华雯丽

计算机技术与发展 2021年9期
关键词:物品协同评分

唐 震,黄 刚,华雯丽

(南京邮电大学 计算机学院、软件学院、网络空间安全学院,江苏 南京 210023)

0 引 言

随着信息技术和互联网环境的不断发展,网络用户的不断增加,人们进入了大数据的信息时代。电子商务市场和社交媒体的逐渐壮大是信息和数据急速增长的主要原因,网络数据的快速增长在丰富互联网生活的同时产生大量无用的数据,这些冗余信息给人们的生活带来了不便。用户对信息的反应速度无法跟上信息的传输及更新速度,用户会对信息的选择产生偏差,这导致了信息利用率的下降,这种类型的问题称为信息过载[1]。解决信息过载的方法一般有两种,其中一种为搜索引擎,利用用户指定的关键字,通过关键词检索被动地过滤出用户感兴趣的信息,速度快但并不能突出用户的个体需求。另一个便是推荐系统,推荐系统通过提供信息过滤机制来帮助用户处理信息过载问题,能够更好地满足用户个性化需求。

推荐系统大致可分为三类:基于内容的推荐[2]、协同过滤[3]推荐方法和混合推荐方法[4]。基于内容的推荐是根据物品的相关信息,用户相关信息以及用户相关行为构建模型找出用户喜爱的物品。协同过滤通过用户反馈信息进行推荐,有两种常用类型:基于用户的协同过滤(UCF)和基于项目的协同过滤(ICF)。混合推荐方法将不同的推荐算法过程或结果进行结合得出最终的推荐结果,组合后能够弥补单个推荐算法的缺点。

协同过滤算法是目前研究最多、应用最广泛的经典推荐算法。该算法实现简单,适用性强,推荐效果较好。但随着互联网数据的几何式增长,协同过滤推荐系统出现了很多问题,由于协同过滤需要利用用户评分矩阵,所以当项目用户过多时,部分评分缺失,计算相似度困难。面对新用户,没有足够的历史数据,无法计算目标用户的相似用户群,给推荐带来了障碍,这是推荐系统中经典的冷启动问题[5]。并且当数据量过大,推荐系统难以避免的会出现推荐速度慢,推荐准确度低的问题。

解决冷启动问题一般通过利用用户的注册信息,用户上下文信息,基于热门数据的推荐等方法。Koren Y等人[6]提出了基于矩阵分解的系统过滤算法,矩阵分解的一个优点是它允许合并额外的信息。当没有明确的反馈时,推荐系统可以使用隐式反馈来推断用户偏好,隐式反馈通过观察用户行为来间接反映用户的偏好。张峰等人[7]提出了使用BP神经网络缓解协同过滤推荐算法的冷启动问题,根据用户评分向量交集大小选择候选最近邻居集,采用BP神经网络预测用户对项的评分,减小候选最近邻数据集的稀疏性,解决了冷启动问题。

推荐系统准确度问题通过混合推荐算法、先进的评分预测算法等加以解决。Cheng-Che Lu和VS-Tseng[8]提出基于内容、基于情感的协同过滤推荐算法,该方法通过对用户选择的反馈,适应用户兴趣的变化,进而推荐出自己喜欢的、更有趣的物品,并进行即时连续推荐。

文中提出了一种融合协同过滤算法和CatBoost[9]的推荐算法,该算法旨在提高推荐系统模型的准确度,实现个性化推荐,提高用户的满意度,并在一定程度上缓解推荐系统冷启动问题。算法思路:通过协同过滤算法构建用户相似度矩阵,根据预测评分公式计算出用户对未评分物品的预测评分,由此得到候选集,再利用CatBoost算法对整体数据集进行训练,对候选集进行预测评分,最后将两个预测评分进行加权融合,得到最终的预测评分从而实现对用户的推荐。由于利用CatBoost算法进行数据集训练利用到的特征较多,可以更好地实现用户个性化推荐,与协同过滤算法进行加权融合后得到的结果更加准确。对于新用户或者历史交互记录缺少的用户,直接用CatBoost算法进行预测并推荐,可以有效缓解用户的冷启动问题。

1 相关工作

1.1 协同过滤算法

协同过滤算法(collaborative filtering recommendation)仍然是目前最为流行、使用最为广泛的推荐算法。该算法的整体推荐效果在很多场景中不亚于新研究出来的其他推荐算法,并且相比较其他算法,协同过滤推荐算法的性能最为稳定。协同过滤算法通过系统提供的用户项反馈来产生推荐,目的是在反馈信息中查找推荐信息,不需要关于用户或项目的额外数据,可以作为推荐系统候选生成器。

基于用户的协作过滤通过分析用户的历史行为数据,然后根据不同用户对相同物品的评分或偏好程度来评测用户之间的相似性,对有相同偏好的用户进行物品推荐。基于项目的协同过滤通过对不同物品的评分来预测项目之间的相似性,再根据用户历史行为数据,得到用户喜欢的物品,通过项目相似性矩阵找到相似度最高的物品,从而推荐给用户。

基于用户的协同过滤和基于项目的协同过滤的核心思想是在整个数据空间寻找用户或项目的前k个最近邻,都需要进行相似度计算。相似度计算的常用方法有余弦相似度、皮尔森(Pearson)相关系数法、欧几里得距离法、杰卡德相似系数法等。

余弦相似度计算公式如下:

(1)

其中,I为所有项目的集合,i为项目集合中的单个项目,Ru,i为用户u对项目i的真实评分,Rv,i为用户v对项目i的真实评分。

皮尔森相关系数计算公式为:

sim(u,v)=

欧几里得距离公式为:

(3)

杰卡德系数为:

(4)

(5)

在协同过滤算法中加入热门商品惩罚项和时间衰减因子可以提高个性化推荐的准确度。惩罚热门物品的原因是如果一个物品过于热门,会有很多用户对其进行评分,但这并不能说明这些用户有着相同的兴趣,所以对热门物品增加一个惩罚项,减少热门物品对用户相似度的影响。

热门商品惩罚项计算公式为:

(6)

其中,N(i)表示对物品i进行过评分的所有用户。

由于用户最近的行为更能表达用户的当前兴趣,所以在计算用户相似度时可以增加时间衰减函数。时间衰减函数为:

(7)

其中,tui表示用户u对物品i产生行为的时间,tvi表示用户v对物品i产生行为的时间。通过对相似度计算方法的改进,得到优化后的余弦相似度公式:

sim(u,v)=

(8)

1.2 CatBoost

CatBoost全称为Gradient Boosting(梯度提升)+Categorical Features(类别型特征),是一种对决策树进行梯度增强的算法,属于集成学习算法的一种。它由Yandex公司的研究人员和工程师开发,用于Yandex和其他公司的搜索、推荐系统、个人助理、自动驾驶汽车、天气预报和许多其他任务[10]。

Gradient Boosting方法是Boosting方法的一种,Boosting模型是通过最小化损失函数得到最优模型,是一个迭代的过程,每一次新的训练的目的是改进前一次训练的效果。Gradient Boosting的主要思想是每次都在前一次模型损失函数的负梯度方向建立新的模型使得损失函数能够不断下降[11]。Gradient Boosting方法适用于异质化数据,梯度提升方法比神经网络的入门门槛更低,使用起来也更简单。近年来,不少学者尝试将集成学习算法运用到推荐系统中,崔岩等[12]提出融合协同过滤和XGBoost的推荐算法,提高了推荐的准确性;李智彬[13]提出融合SVD与LightGBM的音乐推荐算法,解决推荐系统冷启动问题。作为最新的集成学习算法由于对CatBoost算法的相关研究较少,还没有学者将其运用在推荐算法中。

CatBoost是一种能够很好地处理类别型特征的梯度提升算法库。根据官方测评结果[14],CatBoost在准确率方面比同类型的XGBoost以及LightGBM表现更加优秀,该测评结果是在部分数据集上进行的实验,在大多数实验对比中,CatBoost都有着较为不错的训练速度与准确率。

CatBoost相比其他梯度提升算法具有两大优势:第一,不需要人为地处理类别型特征,CatBoost算法可以直接使用类别特征进行模型训练,CatBoost使用独特的方法处理类别特征[15]。首先对样本进行随机排序,然后针对类别型特征中的某个取值,每个样本的该特征转为数值型时都是基于排在该样本之前的类别标签取均值,同时加入了优先级和优先级的权重系数。并且可以将类别特征进行组合,利用特征之间的联系,这极大地丰富了特征维度。定义编码值的公式为:

(9)

类别特征的任何组合都可以视为新特征。例如,假设任务是电影推荐,有两个特征:用户ID和电影类型,某些用户喜欢战争类的电影。在将用户ID和电影类型转换为数字特征时,会丢失此信息。将用户ID与电影类型两种特征进行组合解决了这个问题,并提供了一个新的特征。

在数据集中,特征组合数与特征数为指数关系,对于特征较多的数据集不可能在算法中考虑所有组合,这样会增加计算量。CatBoost在决策树的新一轮拆分时,以贪婪的方式对特征进行组合[16]:对于树中的第一个拆分不考虑组合。在下一个分割节点选择时,CatBoost将所有组合特征和分类特征与数据集中的所有分类特征组合在一起。组合值会动态转换为数字,通过计算它的TS(target statistics)值作为新的特征值参与树模型构建。CatBoost通过以下方式生成数字和类别特征的组合:在决策树中,所有的拆分都被作为具有两个值的类别特征,采用与类别特征相同的组合方式进行组合使用。

CatBoost相对于其他梯度提升算法的第二个优势:在选择生成树结构时,计算叶子节点的算法可以避免过拟合。传统的GBDT算法存在由于梯度估计偏差引起的过拟合问题,预测偏差是由一种特殊类型的目标泄漏引起的。CatBoost提出使用Ordered boosting[16]的方法来解决预测偏差从而得到梯度步长的无偏估计。Ordered boosting算法首先会生成一个长度为n的序列,对每个样本xi训练出一个单独的模型Mi,使得Mi是仅利用了序列中的前i个样本,不包含xi的训练集得到的训练模型。利用Mj-1训练模型得到第j个样本的梯度估计。

CatBoost同时具有CPU和GPU实现。GPU的实现允许更快的训练,同时还具有快速的CPU评分实现。对于数值密集型特征的训练,最重要的就是找到最佳分割,这是GBDT算法最主要的计算负担。CatBoost使用对称决策树作为基础学习者,并将特征离散化为固定数量的箱(bins),以减少内存使用量,在训练模型时可以设置最大箱数[17]。

2 融合协同过滤与CatBoost算法的推荐模型

2.1 算法思想

本模型融合CatBoost与协同过滤的算法为用户进行推荐,形成新的算法模型UCF-CB。由于传统的协同过滤算法根据用户评分信息计算用户对评分物品的预测评分从而进行推荐,随着网络信息的发展,用户以及物品的信息不断增加,协同过滤难以满足用户的个性化需求。融合CatBoost的协同过滤算法可以更全面地对用户及物品信息进行分析,得到更为准确的预测评分,提高用户的满意度。本算法的协同过滤算法模块,利用优化后的余弦相似度公式计算出目标用户的相似用户群,并对相似性进行排序,通过预测评分公式得到召回集并对召回集进行排序得到候选集。再利用CatBoost算法对数据集进行训练,对候选集进行二次评分并将两次评分结果进行融合,通过对参数以及权值的更新,达到提高算法准确度的目的,最后利用Top-N生成推荐列表。

2.2 算法描述

本算法包括通过协同过滤产生召回集,利用CatBoost进行模型训练并对召回集的物品进行二次评分,生成推荐三个阶段。算法流程如图1所示。

图1 算法流程

三个阶段具体实现步骤为:

阶段1:生成召回集D。

输入:用户历史评分数据。

输出:用户召回集D。

算法步骤:

(1)将数据集进行划分,70%的数据作为训练集,30%的数据作为测试集。

(2)在训练集中计算用户之间的相似度,采用加入热门商品惩罚项和时间衰减因子的优化算法复杂度的余弦相似度公式(8)进行相似度计算,并构建相似度矩阵。

(3)选取前k个目标用户近邻,利用式(5)计算目标用户对未评分项目的预测评分。

(4)对预测评分进行排序,组成召回集D。

阶段2:CatBoost模型训练。

输入:用户历史交互数据,用户特征数据,物品特征数据。

输出:训练好的CatBoost模型。

算法步骤:

(1)整合输入数据,提取特征,生成训练集。

(2)对部分特征进行优化处理,利用CatBoost对训练集进行模型训练。

(3)优化模型,使用GridSearchCV对模型进行调参。

(4)得到优化后的模型,保存模型。

阶段3:产生推荐列表。

输入:协同过滤召回集D,协同过滤一次预测评分数据,CatBoost模型。

输出:用户推荐列表。

(1)在召回集中,选取每位用户评分最高的前k个物品,形成候选集。

(2)利用训练好的CatBoost模型对候选集进行二次评分预测,与协同过滤一次评分进行加权,得到最终的预测评分,将项目最终得分进行排序。

(3)利用Top-N产生推荐列表反馈给目标用户。

3 实验结果与分析

3.1 实验数据集

文中采用的数据集是MovieLens-1m数据集,MovieLens-1M数据集含有来自6 040名用户对3 952部电影的100余万条评分数据。分为三个表:用户评分信息、用户信息、电影信息。其中用户信息包括用户id,用户性别,用户年龄,用户职业和压缩编码,其中年龄1对应1~18岁(不包含18岁),18表示18~24岁,25表示25~34岁,35表示35~44岁,45表示45~49岁,50表示50~55岁,56表示大于等于56岁,部分用户信息如表1所示。电影信息包括电影id、电影名称、电影类型,部分电影信息如表2所示。评分数据由6 040名用户对3 952部电影的评分组成,一共1 000 209条数据,包括用户和电影ID,得分值以及交互信息产生的时间戳,部分评分信息如表3所示。

表1 用户信息

表2 电影信息

表3 评分信息

表1中的Zip-code为压缩编码,Occupation为用户职业编号。

表2中Genres为电影类型特征,由符号|隔开,整个数据集共有18个类别特征。

Timestamp为用户打分的时间戳,用户评分范围为1~5,没有0分选择。

3.2 数据预处理

如果使用原始数据集进行集成模型训练,可利用到的特征仅有Gender,Age,Occupation,Genres四类。特征太少会导致模型训练出来的效果较差,所以需要从原始数据中提取出更多特征,提高数据集特征的维度。

首先处理Genres中的电影类型特征,将特征逐一提取出来,构造18*N的特征矩阵,其中N为评分数据总条数,18为特征总数。将矩阵逐列添加到评分信息文件中,列名为电影类型的名称。

从Title中提取出电影的相关上映时间,将上映时间加入到评分信息中,再从用户打分的时间戳中提取出用户打分的年份,将用户对电影的评分年份也作为一个特征,最后删除掉无用的信息,Zip-code,Title,Timestamp,Genres,得到最终的训练数据集。

3.3 评价标准

文中提出的算法会得到用户对于未评分物品的预测评分,所以使用均方误差(mean squared error,MSE)作为预测评分准确度指标。计算公式如下:

(10)

均方误差可以评价数据的变化程度,MSE的值越小,预测模型的精确度越高。

3.4 实验结果与分析

(1)Boosting类算法准确率对比。

将数据集划分,在训练集上使用CatBoost算法对数据进行训练,进行参数调节,使用GridSearchCV对模型进行参数调整。将task_type参数设置为“GPU”,可以有效提高模型的运行效率。对树的深度depth,生成树的数量iterations,学习率learning_rate,子样本subsample,对象采样方法bootstrap_type,随机子空间方法rsm等参数分别进行调参设置。最终更新depth=10iterations=1 100,learning_rate=0.15,rsm=0.1,subsample=0.66。此时得到最佳训练模型。图3为学习率对应的得分值,评分标准为“r2”得分值,当学习率为0.15时,模型效果最好。将调节好的模型进行保存,在测试集上对模型进行效果测试。在此数据集上,分别利用三种流行的boosting算法进行实验,分别得到三种算法在训练集以及测试集上的结果。由图2的实验结果显示,在此数据集上CatBoost与LightGBM表现几乎没有差别,CatBoost在测试集上的表现略微优于LightGBM,提升了约1.5%,XGBoost算法相对来说效果较差。以上数据在一定程度上证明了CatBoost算法在推荐系统中的可行性。

图2 Boosting算法准确性对比

图3 CatBoost学习率得分

(2)召回集各算法准确率对比。

在2.2节算法阶段1中,说明了召回集的生成过程。召回集D共有233 329条数据,占总数据量的23.3%,混合XGBoost的协同过滤算法MSE值为0.800 3,文中提出的UCF-CB算法的MSE为0.693 15。将文中算法与文献[18]提出的Weighted KM-Slope-Vu算法以及文献[19]提出的WSO算法进行对比(见图4),文中算法的MSE均小于对比算法,表明提出的推荐算法在准确性上要优于对比算法。同时相比较在测试集上的评分预测结果,UCF-XGB与UCF-CB算法在准确性上都比原始的算法要有所提升。

图4 召回集上算法对比

(3)最终推荐结果分析。

为了最终产生推荐列表,本实验在召回集中对每个用户选取协同过滤评分最高的前k个物品,取k值为8,共计42 211项,重新组成候选集,用混合模型进行评分预测。按照最终评分利用Top-N算法推荐给用户。这里的k值可以根据要求推荐的数量而定,要求更精确的推荐,可以适当减小k值,要求更广泛的推荐,可以加大k值。

最终的混合模型UCF-CB在D1上的MSE为0.637 81,协同过滤算法的MSE为0.794 3,UCF-XGB算法的MSE为0.749 67。对比原始的协同过滤算法以及UCF-XGB有明显的提升,文中提出的算法模型在最终的推荐集上有着较好的表现(见图5)。

图5 混合模型分析

4 结束语

文中提出的混合推荐算法UCF-CB,通过改进后的协同过滤算法得到用户的召回集D,利用训练后的CatBoost算法对召回集进行二次评分预测,与协同过滤一次评分进行加权融合,得到最终的预测评分。在实验2中,证明了该算法的优越性。最后将召回集进行压缩得到D1,通过UCF-CB算法进行评分预测,生成推荐列表反馈给用户。文中将不同的算法进行混合,提高了推荐系统的准确性,通过实验对比验证了相比较传统的系统过滤算法有着明显的提高,并且利用CatBoost集成学习模型可以解决推荐系统中的冷启动问题。同时文中提出的算法也有不足之处,由于协同过滤算法在庞大的数据集上计算量过大,运行效率较差,会导致混合算法整体的效率较低。所以,下一步的工作将研究如何提高算法模型的运行效率,将矩阵分解运用到协同过滤算法中,解决数据稀疏性,对原始数据进行降维,减少计算量,使模型的运行效率更高。

猜你喜欢

物品协同评分
急性上消化道出血的危险分级及临床应用
创造力的“阴暗面”与“创新—保新”的协同论
车联网系统驾驶行为评分功能开发
称物品
家校社协同育人 共赢美好未来
基于安全多方计算技术的隐私保护打分系统设计
APACHEⅡ评分在制定ICU患者护理干预措施中的应用研究
京津冀协同发展加快向纵深推进
京津冀协同发展
图画捉迷藏