掌桥专利:专业的专利平台
掌桥专利
首页

一种产品推荐方法、装置及电子设备

文献发布时间:2023-06-19 18:25:54


一种产品推荐方法、装置及电子设备

技术领域

本公开涉及计算机技术领域,尤其涉及机器学习、智能推荐等技术领域。

背景技术

在相关技术中,产品公司通常需要为想要购买产品的用户推荐合适的产品。

发明内容

本公开提供了一种产品推荐方法、装置、设备以及存储介质。

根据本公开的第一方面,提供了一种产品推荐方法,包括:

确定目标推荐用户;

将所述目标推荐用户的用户特征输入至产品推荐模型,得到所述产品推荐模型输出的所述目标推荐用户对各候选推荐产品的感兴趣程度,所述产品推荐模型是预先通过样本数据训练得到的,所述样本数据包括样本用户的用户特征、所述候选推荐产品中所述样本用户拥有的正样本产品,和与所述正样本产品类别相同且所述样本用户未拥有的负样本产品;

根据所述感兴趣程度,从所述候选推荐产品中确定目标推荐产品;

向所述目标推荐用户推荐所述目标推荐产品。

根据本公开的第二方面,提供了一种产品推荐模型的训练方法,包括:

获取样本用户的用户特征、候选推荐产品中所述样本用户拥有的正样本产品,和与所述正样本产品类别相同且所述样本用户未拥有的负样本产品;

将所述用户特征输入至原始训练模型中,得到所述原始训练模型输出的各所述样本用户对各所述候选推荐产品的感兴趣程度;

根据所述感兴趣程度构建训练损失,其中,所述训练损失与所述样本用户对所述正样本产品的感兴趣程度负相关,且与所述样本用户对所述负样本产品的感兴趣程度正相关;

根据所述训练损失调整所述原始训练模型,得到产品推荐模型。

根据本公开的第三方面,提供了一种产品推荐装置,包括:

用户确定模块,用于确定目标推荐用户;

兴趣输出模块,用于将所述目标推荐用户的用户特征输入至产品推荐模型,得到所述产品推荐模型输出的所述目标推荐用户对各候选推荐产品的感兴趣程度,所述产品推荐模型是预先通过样本数据训练得到的,所述样本数据包括样本用户的用户特征、所述候选推荐产品中所述样本用户拥有的正样本产品,和与所述正样本产品类别相同且所述样本用户未拥有的负样本产品;

目标确定模块,用于根据所述感兴趣程度,从所述候选推荐产品中确定目标推荐产品;

产品推荐模块,用于向所述目标推荐用户推荐所述目标推荐产品。

根据本公开的第四方面,提供了一种产品推荐模型的训练装置,包括:

特征获取模块,用于获取样本用户的用户特征、候选推荐产品中所述样本用户拥有的正样本产品,和与所述正样本产品类别相同且所述样本用户未拥有的负样本产品;

兴趣输出模块,用于将所述用户特征输入至原始训练模型中,得到所述原始训练模型输出的各所述样本用户对各所述候选推荐产品的感兴趣程度;

损失建立模块,用于根据所述感兴趣程度构建训练损失,其中,所述训练损失与所述样本用户对所述正样本产品的感兴趣程度负相关,且与所述样本用户对所述负样本产品的感兴趣程度正相关;

模型确定模块,用于根据所述训练损失调整所述原始训练模型,得到产品推荐模型。

根据本公开的第五方面,提供了一种电子设备,包括:

至少一个处理器;以及

与所述至少一个处理器通信连接的存储器;其中,

所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行第一方面和第二方面中任一项所述的方法。

根据本公开的第六方面,提供了一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行根据第一方面和第二方面中任一项所述的方法。

根据本公开的第七方面,提供了一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现根据第一方面和第二方面中任一项所述的方法。

应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。

附图说明

附图用于更好地理解本方案,不构成对本公开的限定。其中:

图1是根据本公开的产品推荐方法的一种流程示意图;

图2是根据本公开的产品推荐方法的另一种流程示意图;

图3是根据本公开的产品推荐模型的训练方法的一种流程示意图;

图4是根据本公开的产品推荐模型的训练方法的另一种流程示意图;

图5是根据本公开的产品推荐模型的训练方法的另一种流程示意图;

图6是根据本公开的产品推荐模型的训练方法的另一种流程示意图;

图7是根据本公开的产品推荐装置的一种结构示意图;

图8是根据本公开的产品推荐模型的训练装置的一种结构示意图;

图9是用来实现本公开实施例的产品推荐方法和产品推荐模型的训练方法的电子设备的框图。

具体实施方式

以下结合附图对本公开的示范性实施例做出说明,其中包括本公开实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本公开的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。

产品制造或营销公司具有多种产品,因此,其常常要为需要购买产品用户推荐合适的产品,使得用户能够便利的获得自己感兴趣的产品,而相关技术中往往不能准确的确定用户对哪种产品感兴趣而不能为用户推荐合适的产品,基于此,本公开提供了一种产品推荐方法,如图1所示,方法包括:

S101,确定目标推荐用户。

S102,将目标推荐用户的用户特征输入至产品推荐模型,得到产品推荐模型输出的目标推荐用户对各候选推荐产品的感兴趣程度。

S103,根据感兴趣程度,从候选推荐产品中确定目标推荐产品。

S104,向目标推荐用户推荐目标推荐产品。

选用该实施例,将目标推荐用户的用户特征输入至产品推荐模型,使得产品推荐模型输出目标推荐用户对各候选推荐产品的感兴趣程度,而产品推荐模型是通过样本数据的训练得到的,样本数据包括样本用户的用户特征、候选推荐产品中样本用户拥有的正样本产品,和与正样本产品类别相同且样本用户未拥有的负样本产品,因此,基于这样的样本数据训练得到的产品推荐模型可以学习到具有不同用户特征的样本用户对各候选推荐产品的感兴趣程度,进而,可以根据目标推荐用户的用户特征预测候选推荐用户的对候选推荐产品的感兴趣程度,进而根据该感兴趣程度确定候选推荐产品中的目标推荐产品,为目标推荐用户推荐目标推荐产品,使得目标推荐用户获得合理的产品推荐,提高了用户体验。

其中,在S101中,目标推荐用户为具有产品购买需求的用户,下文以保险产品为例,在此示例中,目标推荐用户即为具有保险购买需求的用户。具体的,可以周期性的获取在网页中查看过产品栏目的用户,将这些用户作为目标推荐用户,可以理解的是,若一个用户查看过产品栏目,则说明该用户可能具有购买某些产品的需求,因此,可以将该用户作为目标推荐用户为其推荐合适的产品。作为另一种示例,可以周期性的查询包含保险产品营销信息的数据库,如hive(一种数据仓库工具),获取各用户的相关营销数据,根据营销数据(如用户购买保险的频次)确定出目标推荐用户。

其中,在S102中,产品推荐模型是预先通过样本数据训练得到的,样本数据包括样本用户的用户特征、候选推荐产品中样本用户拥有的正样本产品,和与正样本产品类别相同且样本用户未拥有的负样本产品。

可以理解的是,当用户购买一类型产品后,可以视为用户已经满足对该类型的产品的需求,示例性的,当用户购买人身类保险后,认为该用户在一定时间内已经不再需要购买人身类保险,因此若用户购买了一个产品而未购买与该产品同类型的其他产品,则说明该用户在一定时间内也不会购买与该产品同类型的其他产品,即该用户对其购买的产品感兴趣,而对该产品同类型的其他产品不感兴趣。示例性的,若用户购买了人身意外伤害保险且未购买人寿保险,则认为用户在一定时间内将不会购买人寿保险,因此认为用户对人寿保险不感兴趣。

因此,样本数据中将样本用户购买的产品标注为正样本产品,而将该样本用户未购买的与正样本产品同类型的产品标注为负样本产品,通过正负样本产品的标注体现样本用户对候选推荐产品的感兴趣程度。而各样本数据又包括了各样本用户的用户特征,因此,使用这样的样本数据训练得到产品推荐模型可以将用户的用户特征与用户对候选推荐产品的感兴趣程度关联起来,进而,在后续将目标推荐用户的用户特征输入至产品推荐模型后,产品推荐模型可以预测出目标推荐用户对各候选推荐产品的感兴趣程度。

其中,样本用户的用户特征可以包括用户的年龄、收入、健康状况等等,相应的,获取的目标推荐用户的用户特征的特征维度应该与样本用户的用户特征的特征维度相同,示例性的,若样本用户的用户特征包括样本用户的年龄,则目标推荐用户的用户特征也应当包括候选推荐用户的年龄。在一种可能的实施例中,样本用户的用户特征是利用专家经验和/或自动特征生成工具根据每个样本用户的相关信息生成的,该相关信息可以包括样本用户的产品购买记录,样本用户的年龄,性别等等。

产品推荐模型输出的感兴趣程度可以以分数表示,候选推荐产品的分数越高则表示该目标推荐用户对该候选推荐产品越感兴趣,在其他示例中,产品推荐模型也可以以等级表示,具体的,输出等级1和等级0,等级1表示该目标推荐用户对该候选推荐产品感兴趣,而等级0表示该目标推荐用户对该候选推荐产品不感兴趣,等等,本公开对感兴趣程度的表示方法并不限定。

在一种可能的实施例中,在用户特征输入至产品推荐模型前,可以对类别型的用户特征先进行label encoder(标签编码器)编码,类别型特征为初始时未使用数值表示的特征,如性别:男、女,而为便于产品推荐模型对这些特征进行处理,这类特征输入至模型之前需要进行数值化编码,例如,将若将男性编码为2,将女性编码为3。

其中,在S103中,根据感兴趣程度,选取目标推荐用户感兴趣程度大的候选推荐产品作为目标推荐产品,以前述感兴趣程度以分数表示的示例为例,若产品推荐模型输出的一个候选推荐产品的感兴趣程度的分数大于预设阈值,则将该候选推荐产品作为目标推荐产品,或者产品推荐模型输出的一个候选推荐产品的感兴趣程度的分数为所有候选推荐产品的感兴趣程度的分数排序中,从大到小排序序号为前预设排序名次,则将该候选推荐产品作为目标推荐产品,以此,从所有候选推荐产品中确定出目标推荐产品。

其中,在S104中,可以理解的是,目标推荐产品为目标推荐用户感兴趣程度较大的候选推荐产品,因此,向目标推荐用户推荐候选推荐产品的推荐成功率较高,而目标推荐用户也可以便利的获得自己感兴趣的产品的相关信息,提高了用户体验。

若在为目标推荐用户推荐产品时,只考虑用户对产品的感兴趣程度而不考虑产品的品质,则可能不能为用户推荐到优质的产品,基于此,本公开还提供了一种产品推荐方法,如图2所示,方法包括:

S201,确定目标推荐用户。

S202,将目标推荐用户的用户特征输入至产品推荐模型,得到产品推荐模型输出的目标推荐用户对各候选推荐产品的感兴趣程度。

S203,根据各感兴趣程度确定目标推荐用户将会拥有各候选推荐产品的添置概率。

S204,根据候选推荐产品的产品特点为各候选推荐产品确定添置权重。

S205,根据添置概率和添置权重确定各候选推荐产品的添置优先级。

S206,根据候选推荐产品的添置优先级从候选推荐产品中确定目标推荐产品。

S207,向目标推荐用户推荐目标推荐产品。

其中,在S201中,此步骤与前述S101相同,具体可以参见S101相关描述,此处不再赘述。

其中,在S202中,此步骤与前述S102相同,具体可以参见S102相关描述,此处不再赘述。

其中,在S203中,根据感兴趣程度确定目标推荐用户对各候选推荐产品的将要拥有的添置概率,其中各候选推荐产品的添置概率为目标推荐用户可能购买该候选推荐产品的概率。具体的,添置概率与感兴趣程度正相关,即目标推荐用户对一个候选推荐产品的感兴趣程度越高,则说明该目标推荐用户购买该候选推荐产品的添置概率越高。作为一种示例,若A候选推荐产品的感兴趣程度为5分,B候选推荐产品的感兴趣程度为6分,则A候选推荐产品的添置概率可以为50%,而B候选推荐产品的添置概率可以为60%。

其中,在S204中,产品特点可以包括候选推荐产品的价格、功能、保质期等等,而对应保险领域,产品特点可以包括该保险产品的保费、保险有效期、保险范围等等,根据不同的产品特点确定该产品的品质,进而根据产品品质为该候选推荐产品确定添置权重。具体的,候选推荐产品的添置权重为目标推荐用户购买该候选推荐产品后,产品公司获得的收益大小的权重。可以为产品品质高的候选推荐产品设置高添置权重,为产品品质第的候选推荐产品设置低添置权重,可以理解,产品品质高,其价格也会相对较高,产品公司的收益也会相对较高。在另一示例中,如在保险领域,可以为保费高,保险有效期长的产品设置高添置权重,可以为保费低,保险有效期段的产品设置低添置权重,可以理解,用户购买的保险产品的保费越高,保险有限期越长,保险公司的收益越高。

其中,在S205中,优先级与添置概率和添置权重正相关。

一个候选推荐产品对应的添置概率越高,则说明目标推荐用户对该候选推荐产品的感兴趣程度越高,而一个候选推荐产品对应的添置权重越高,则说明该候选推荐产品的品质越高,而此步骤结合添置概率和添置权重确定添置优先级,即是结合了感兴趣程度和品质为目标推荐用户确定添置优先级,使得一个候选推荐产品的添置优先级体现了该候选推荐产品感兴趣程度和品质,并且一个候选推荐产品的感兴趣程度越大,品质越高,则该候选推荐产品对应的添置优先级就越高。

其中,在S206中,将候选推荐产品中对应的添置优先级较高的候选推荐产品作为目标推荐产品。例如将添置优先级最高的候选推荐产品作为目标推荐产品,或者将添置优先级高于预设数量个候选推荐产品的候选推荐产品作为目标推荐产品。可以理解的是,一个候选推荐产品的添置优先级越高,则说明该候选推荐产品的感兴趣程度越高且品质越高,则该候选推荐产品既符合目标推荐用户的兴趣,又优质,因此,该候选推荐产品应该作为目标推荐产品被推荐给目标推荐用户。在另一种示例中,还可以根据添置优先级的等级从高到低将候选推荐产品进行排序,选取排序靠前的预设数量个候选推荐产品作为目标推荐产品。

其中,在S206中,此步骤与前述S104相同,具体可以参见S104相关描述,此处不再赘述。

选用该实施例,可以结合目标推荐用户的感兴趣程度和候选推荐产品的品质,为目标推荐用户确定出既符合目标推荐用户的兴趣,又具有高品质的目标推荐产品进行推荐,进一步的提高了用户体验。

在前述方法中,是基于产品推荐模型输出的感兴趣程度确定目标推荐产品,进而为目标推荐用户推荐目标推荐产品的,可以理解的是,产品推荐模型对候选推荐用户输出的感兴趣程度的准确度直接影响到能否为合适的用户推荐第二产品,基于此,本公开提供了一种产品推荐模型的训练方法,以提高产品推荐模型的准确性,如图3所示,方法包括:

S301,获取样本用户的用户特征、候选推荐产品中样本用户拥有的正样本产品,和与正样本产品类别相同且样本用户未拥有的负样本产品。

S302,将用户特征输入至原始训练模型中,得到原始训练模型输出的各样本用户对各候选推荐产品的感兴趣程度。

S303,根据感兴趣程度构建训练损失。

S304,根据训练损失调整原始训练模型,得到产品推荐模型。

其中,在S301中,样本用户、正样本产品和负样本产品在前述S102中已经解释,可以参见前述S102的相关描述,此处不再赘述。

其中,在S302中,原始训练模型为还未进行训练的模型,其可以是XGBoost(eXtreme Gradient Boosting,极致梯度提升)模型,也可以是LightGBM(Light GradientBoosting Machine,一款基于决策树算法的分布式梯度提升框架)等二分类模型,本公开对此并不限定。将样本用户的用户特征输入至原始训练模型中,使得原始训练模型输出目标推荐用户对各候选推荐产品的感兴趣程度,该感兴趣程度如前所述,可以以分数表示,也可以以其他形式表示。

其中,在S303中,训练损失与样本用户对正样本产品的感兴趣程度负相关,且与样本用户对负样本产品的感兴趣程度正相关。

可以理解的是,正样本产品为样本用户拥有的候选推荐产品,因此,必然是样本用户对正样本产品感兴趣程度较大才会拥有正样本产品,而负样本产品为样本用户没有拥有的候选推荐产品,可见,样本用户对负样本产品的感兴趣程度较低。因此,若原始训练模型准确,则其应该输出样本用户对正样本产品的感兴趣程度较大,而对负样本产品的感兴趣程度较小,换言之,若正样本用户对应的感兴趣程度越小,则说明原始训练模型不够准确,训练损失应该越大,相应的,若负样本产品对应的感兴趣程度越大,则说明原始训练模型不够准确,训练损失应该越大,基于此,构建训练损失。具体的,训练损失可以由损失函数表示,例如huber损失函数、softmax损失函数等等,本公开对此并不限定。

其中,在S304中,根据训练损失调整原始训练模型的相关参数,直到基于调整后的原始训练模型输出的感兴趣程度构建的训练损失小于某个阈值,例如输出的样本用户对正样本产品的感兴趣的程度较高,对负样本产品的感兴趣的程度较低,可以认为该调整后的原始训练模型可以准确的预测目标推荐用户对候选推荐产品的的感兴趣程度,进而将该原始训练模型作为产品推荐模型,以便后续使用。

选用该实施例,可以基于候选推荐产品中正样本产品和负样本产品的特点,为原始训练模型构建损失函数,根据该损失函数再调整原始训练模型,指导调整后的原始训练模型可以准确输出样本用户对正样本产品和负样本产品的感兴趣程度,建立了用户特征与用户对候选推荐产品的感兴趣程度的映射关系,进而得到可以准确预测目标推荐用户对候选推荐产品的感兴趣程度的产品推荐模型。

在产品推荐模型的训练过程中,用户特征的确定也较为重要,若选取的样本用户的用户特征随着时间变化较大,则可以理解该用户特征不够稳定,不能准确体现该用户的相关情况,进而根据这样的用户特征训练得到的产品推荐模型也可能不能准确预测目标推荐用户对候选推荐产品的感兴趣程度,基于此,本公开还提供了一种产品推荐模型的训练方法,如图4所示,方法包括:

S401,获取样本用户在各原始特征维度上的样本特征分布以及跨时间测试用户在各原始特征维度上的跨时间特征分布。

S402,从原始特征维度中筛除样本特征分布与跨时间特征分布差异满足预设条件的特征维度,得到目标特征维度。

S403,获取样本用户在目标特征维度上的用户特征、候选推荐产品中样本用户拥有的正样本产品,和与正样本产品类别相同且样本用户未拥有的负样本产品。

S404,将用户特征输入至原始训练模型中,得到原始训练模型输出的各样本用户对各候选推荐产品的感兴趣程度。

S405,根据感兴趣程度构建训练损失。

S406,根据训练损失调整原始训练模型,得到产品推荐模型。

其中,在S401中,其中,跨时间测试用户为在跨时间窗口内拥有正样本产品的用户,跨时间窗口与历史时间窗口不重叠,历史时间窗口为所述样本用户拥有正样本产品的时间窗口。

由于跨时间窗口与历史时间窗口不重叠,因此,跨时间测试用户拥有正样本产品的时间与样本用户拥有正样本产品的时间不重叠,例如,若样本用户对应的历史时间窗口为1-6月,则跨时间测试用户对应的跨时间窗口可以为在7月份或8月份等不与1-6月重叠的月份。

原始特征维度为初始时获取的样本用户的所有原始特征所处的特征维度,可以包括年龄、性别、健康状况、收入等等维度,各样本用户在各原始特征维度上的原始特征有其对应的分布情况,将该分布情况作为样本用户在各原始特征维度上的样本特征分布。而跨时间特征分布为跨时间测试用户的原始特征在原始特征维度上的分布情况。

其中,在S402中,可以理解的是,由于样本用户和跨时间测试用户不在一个时间窗口,因此,样本用户和跨时间测试用户对正样本产品的初始拥有时间差异较大。而若样本特征分布和跨时间特征分布中存在分布差异较大的特征维度,则说明该特征维度的特征会随着时间的变化而有较大的变化,进而该特征维度的特征不够稳定,可以将该特征维度筛除。因此,样本特征分布与跨时间特征分布在某个特征维度的特征分布差异越大,则该特征维度越可能满足预设条件,示例性的,预设条件可以为分布差异大于特定阈值。将原始特征维度中满足预设条件的特征维度筛除,即是将不稳定的原始特征筛除,得到稳定的能够体现样本用户的相关特点的目标特征维度上的用户特征。

在一种可能的实施例中,可以通过以下方法确定满足预设条件的特征维度并进行筛除:

S4021,通过稳定性指标评估样本特征分布和跨时间特征分布在原始特征维度上的分布差异,得到第一评估结果。

S4022,根据第一评估结果筛除原始特征维度中样本特征分布与跨时间特征分布差异满足第一预设条件的特征维度,得到第一特征维度。

S4023,通过对抗验证方式评估样本特征分布和跨时间特征分布在第一特征维度上的分布差异,得到第二评估结果。

S4024,根据第二评估结果筛除第一特征维度中样本特征分布与跨时间特征分布差异满足第二预设条件的特征维度,得到目标特征维度。

其中,在S4021中,稳定性指标可以反映样本特征分布在各分数段(各特征维度)的分布与跨时间特征分布的稳定性,通常稳定性指标可以为PSI(Population StabilityIndex)指标,通过该稳定性指标可以评估出样本特征分布和跨时间特征分布在原始特征维度中分布差异,得到关于各个特征维度的特征分布的分布差异的第一评估结果。

其中,在S4022中,根据该第一评估结果,确定各个原始特征维度中满足第一预设条件的特征维度进行筛除,得到第一特征维度。其中,第一预设条件可以是原始特征维度上的特征分布差异大于预设阈值,可以理解的是,样本特征分布和跨时间特征分布在某个原始特征维度上分布差异越大,则该原始特征维度越可能满足第一预设条件。

其中,在S4023中,对抗验证方式(adversarial validation)为一种确认训练集(样本特征分布)和测试集(跨时间特征分布)的分布是否一致的方法,对抗验证作为一种特征筛选方法时,可以找出时序波动明显的特征,帮我们快速找到在原始特征维度上不稳定的特征维度的特征。因此,可以基于对抗验证方式,对已经经过稳定性指标评估筛除的第一特征维度再次进行评估,得到第一特征维度中各个特征维度的特征分布的分布差异的第二评估结果。

其中,在S4024中,根据该第二评估结果,确定各个第一特征维度中满足第二预设条件的特征维度进行筛除,得到目标特征维度。其中,第二预设条件可以是第一特征维度上的特征分布差异大于预设阈值,可以理解的是,样本特征分布和跨时间特征分布在某个特征维度上分布差异越大,则该特征维度越可能满足第二预设条件。

选用该实施例,稳定性指标和对抗验证方式都能准确评估特征分布的稳定性,而通过稳定性指标和对抗验证方式评估了原始特征维度上样本特征分布和跨时间特征分布的分布差异,进而根据评估结果筛选出了目标特征维度,进一步的提高了后续在目标特征维度上获取的用户特征的稳定性。

其中,在S403中,可以理解的是,样本用户在目标特征维度上的用户特征是稳定的,可以准确体现样本用户相关特点的用户特征,使用该用户特征训练原始推荐模型,使得后续训练得到产品推荐模型输出的感兴趣程度更加准确。

其中,在S404中,此步骤S302相同,具体可以参见S302的相关描述,此处不再赘述。

其中,在S405中,此步骤S303相同,具体可以参见S303的相关描述,此处不再赘述。

其中,在S406中,此步骤S304相同,具体可以参见S304的相关描述,此处不再赘述。

选用该实施例,通过对原始特征维度中特征不稳定的特征维度的筛除,实现有目的地获取稳定分布在目标特征维度的用户特征,使得后续根据这些稳定的样本用户的用户特征训练得到的产品推荐模型更加准确。

为了确定训练好的产品推荐模型预测的目标推荐用户对候选推荐产品的感兴趣程度的准确性,可以对产品推荐模型进行验证,基于此,本公开还提供了一种产品推荐模型的验证方法,如图5所示,方法包括:

S501,获取验证样本的用户特征、候选推荐产品中验证样本拥有的正样本产品,和与正样本产品类别相同且验证样本未拥有的负样本产品。

S502,将验证样本的用户特征输入至产品推荐模型,得到产品推荐模型输出的各验证样本对各候选推荐产品的感兴趣程度。

S503,确定感兴趣程度与正样本产品和负样本产品的匹配程度。

S504,根据匹配程度验证产品推荐模型,得到验证结果。

其中,在S501中,验证样本与样本用户类似,为包括在历史时间窗口拥有第一产品且未拥有第二产品的负样本用户,但是具体的,样本用户为用于训练产品推荐模型的样本,而验证样本为用于验证产品推荐模型的样本,样本用户和验证样本包含的具体的样本是不同的,如样本用户中包括用户A,则验证样本中便不会包括用户A。

其中,在S502中,此步骤与S102类似,不同的是S102输入的是目标推荐用户的用户特征,得到的是目标推荐用户对候选推荐产品的感兴趣程度,而S502输入的是验证样本的用户特征,得到的是验证样本对候选推荐产品的感兴趣的程度,具体可以参见S102的相关描述,此处不再赘述。

其中,在S503中,如前所述,负样本产品为验证样本未拥有的与正样本产品同类别的候选推荐产品,因此,若产品推荐模型准确,则应输出验证样本对候选推荐产品中负样本产品的感兴趣程度较低,正样本产品为验证样本拥有的的候选推荐产品,因此,若产品推荐模型准确,则应输出验证样本对候选推荐产品中正样本产品的感兴趣程度较高。因此,可以基于产品推荐模型输出的验证样本对候选推荐产品的感兴趣程度,判断各感兴趣程度是否与负样本产品和正样本产品的特点匹配,即,若产品推荐模型输出的验证样本对正样本产品的感兴趣程度高,则说明该感兴趣程度与正样本产品匹配,若产品推荐模型输出的验证样本对负样本产品的感兴趣程度低,则说明该感兴趣程度与负样本产品匹配。基于此,确定各正样本产品和负样本产品与感兴趣程度的匹配程度。

在一种可能的实施例中,本公开提供了一种确定感兴趣程度与正样本产品和负样本产品匹配程度的方法,方法包括:

S5031a,根据验证样本对各候选推荐产品的感兴趣程度统计AUC和/或KS指标。

S5032a,根据AUC和/或KS指标确定感兴趣程度与候选推荐产品中正样本产品和候选推荐产品中负样本产品的匹配程度。

其中,在S5031a中,AUC(Area under curve)在机器学习领域中是一种模型评估指标,具体的,AUC为roc(receiver operating characteristic curve)曲线下的面积,用于二分类模型的评价,其可以根据产品推荐模型输出的验证样本对正样本产品的感兴趣程度和验证样本对负样本产品的感兴趣程度进行计算。

KS(Kolmogorov-Smirnov)指标常用于评估模型区分度,倾向于从概率角度衡量正负样本分布之间的差异。其可以根据产品推荐模型输出的验证样本对正样本产品的感兴趣程度和验证样本对负样本产品的感兴趣程度进行计算。

其中,在S5032a中,计算得到的AUC指标越大,说明感兴趣程度与候选推荐产品中正样本产品和候选推荐产品中负样本产品的匹配程度越高,计算得到的KS指标越大,说明感兴趣程度与候选推荐产品中正样本产品和候选推荐产品中负样本产品的匹配程度越高。

选用该实施例,通过计算AUC和/或KS指标,确定出感兴趣程度与候选推荐产品中正样本产品和候选推荐产品中负样本产品的匹配程度,进而确定出产品推荐模型的准确度,提高了本公开得到关于产品推荐模型的验证结果的准确度。

在另一种可能的实施例中,本公开还提供了一种确定感兴趣程度与正样本产品和负样本产品匹配程度的方法,方法包括:

S5031b,根据感兴趣程度将候选推荐产品进行等频分箱,得到各箱体。

S5032b,统计每个箱体内正样本产品的正样本率和/或负样本产品的负样本率。

S5033b,确定正样本率和/或负样本率与箱体的匹配程度,作为感兴趣程度与正样本产品和负样本产品的匹配程度。

其中,在S5031b中,等频分箱是将数据离散化的一种方法,等频分箱使得每个箱体包括的值一样多。本公开中根据感兴趣程度对验证样本进行等频分箱可以是将验证样本根据其对应的感兴趣程度按照感兴趣程度的大小进行分箱,例如,若感兴趣程度以分数表示,可以将感兴趣程度为1的候选推荐产品放在一个箱体,将感兴趣程度为2的候选推荐产品放在另一个箱体,以此类推,对各验证样本进行等频分箱。

其中,在S5032b中,可以理解的是,各个箱体中可能包括正样本产品和/或负样本产品,而各正样本产品数量占本箱体所有候选推荐产品的数量的比例即为正样本率,各负样本产品数量占本箱体所有候选推荐产品的数量的比例即为负样本率。示例性的,若一个箱体中有5个候选推荐产品,其中1个为正样本产品,4个负样本产品,则该箱体的正样本率为20%,负样本率为80%。

其中,在S5033b中,正样本率和/或负样本率与箱体的匹配程度为正样本率和/或负样本率与箱体中各正样本产品和/或负样本产品对应的感兴趣程度的匹配程度,换言之,一个箱体的正样本率越高,且其对应的感兴趣程度也应该越高,则说明该正样本率与该箱体匹配程度高,相应的,若一个箱体的负样本率越低,且其对应的感兴趣程度也应该越低,则说明该负样本率与该箱体匹配程度高。

其中,箱体是根据其中的候选推荐产品对应的感兴趣程度划分的,因此,针对一个箱体,其会对应一个感兴趣程度。以感兴趣程度以分数表示为例,若A箱体对应的感兴趣程度的分数为1,即感兴趣程度较低,则说明产品推荐模型预测该箱体中验证样本对候选推荐产品的感兴趣程度低,B箱体对应的感兴趣程度的分数为6,即感兴趣程度较高,则说明产品推荐模型预测该箱体中验证样本对候选推荐产品的感兴趣程度高,可以理解,理论上A箱体中的正样本产品应该少于B箱体,即A箱体的正样本率应该小于B箱体的正样本率,而若统计出A箱体中正样本率为60%,统计出B箱体中正样本率为20%,则说明A箱体和B箱体的正样本率与A箱体和B箱体不匹配。相应的,若A箱体对应的感兴趣程度高,B箱体对应的感兴趣程度低,且A箱体的负样本率高,B箱体的负样本率低,则说明理论上验证样本对A箱体的候选推荐产品更感兴趣,但是A箱体中验证样本不感兴趣的候选推荐产品较多,B箱体中验证样本不感兴趣的候选推荐产品较少,可见,此时A箱体和B箱体的负样本率与A箱体和B箱体不匹配。以此,将箱体与正样本率和/或负样本率的匹配程度作为感兴趣程度与正样本产品和负样本产品的匹配程度,使得获得的匹配程度的确定更加准确。

选用该实施例,通过离散统计的方法,可以准确的确定出验证样本与产品推荐模型输出的验证样本对候选推荐产品的感兴趣程度的匹配程度,使得后续进而根据该匹配程度确定产品推荐模型是否准确,得到验证结果,提高了本公开得到关于产品推荐模型的验证结果的准确度,进一步的提高了本公开产品推荐方法的推荐准确度。

在另一种实施例中,还可以统计产品推荐模型输出的各验证样本对正样本产品和/或负样本产品的感兴趣程度的大小是否在前预设排名或后预设排名中,例如,若多个正样本产品的感兴趣程度较大,其感兴趣程度的大小排名在所有候选推荐产品的感兴趣程度前三,若多个负样本产品的感兴趣程度较消,其感兴趣程度的大小排名在所有候选推荐产品的感兴趣程度后三,则说明感兴趣程度与正样本产品和负样本产品的匹配程度较高。

其中,在S504中,可以理解的是,感兴趣程度与正样本产品和负样本产品不匹配的情况多,则说明产品推荐模型输出的验证样本对候选推荐产品的感兴趣程度不准确,而若感兴趣程度与正样本产品和负样本产品匹配的情况多,或者都匹配,则说明书产品推荐模型输出的验证样本对候选推荐产品的感兴趣程度准确,基于此,获得产品推荐模型的验证结果。

选用该实施例,通过验证样本验证产品推荐模型的准确性,得到验证结果,以便后续根据验证结果对产品推荐模型的调整后再进行使用,提高了本公开产品推荐方法的推荐准确度。

为了更好的说明上述产品推荐模型的训练方法的具体实施过程,本公开还提供了产品推荐模型的训练方法的流程示意图,如图6所示,下面将结合图6进行说明:

S601,定义样本,确定出样本用户。

S602,数据提取,将样本用户和样本用户所有可能被用到的特征导入到建模环境中。

S603,原始特征回溯、生成,利用专家经验和自动特征生成工具产出每条样本用户对应的原始特征。

S604,特征筛选,将原始特征进行筛选,得到目标特征维度下的用户特征。

S605,模型训练,通过用户特征训练原始推荐模型,得到产品推荐模型。

S606,模型评估,通过等频分箱等评估方法对产品推荐模型进行评估,确定产品推荐模型输出的候选推荐产品的感兴趣程度的准确性。

根据本公开的实施例,本公开还提供了一种产品推荐装置,如图7所示,包括:

用户确定模块701,用于确定目标推荐用户;

兴趣输出模块702,用于将所述目标推荐用户的用户特征输入至产品推荐模型,得到所述产品推荐模型输出的所述目标推荐用户对各候选推荐产品的感兴趣程度,所述产品推荐模型是预先通过样本数据训练得到的,所述样本数据包括样本用户的用户特征、所述候选推荐产品中所述样本用户拥有的正样本产品,和与所述正样本产品类别相同且所述样本用户未拥有的负样本产品;

目标确定模块703,用于根据所述感兴趣程度,从所述候选推荐产品中确定目标推荐产品;

产品推荐模块704,用于向所述目标推荐用户推荐所述目标推荐产品。

在一种可能的实施例中,所述目标确定模块703,包括:

概率确定子模块,用于根据各所述感兴趣程度确定所述目标推荐用户将会拥有各所述候选推荐产品的添置概率;

权重确定子模块,用于根据所述候选推荐产品的产品特点为各所述候选推荐产品确定添置权重;

优先级确定子模块,用于根据所述添置概率和所述添置权重确定各所述候选推荐产品的添置优先级,所述优先级与所述添置概率和所述添置权重正相关;

目标确定子模块,用于根据所述候选推荐产品的添置优先级从所述候选推荐产品中确定目标推荐产品。

根据本公开的实施例,本公开还提供了一种产品推荐模型的训练装置,如图8所示,包括:

特征获取模块801,用于获取样本用户的用户特征、候选推荐产品中所述样本用户拥有的正样本产品,和与所述正样本产品类别相同且所述样本用户未拥有的负样本产品;

兴趣输出模块802,用于将所述用户特征输入至原始训练模型中,得到所述原始训练模型输出的各所述样本用户对各所述候选推荐产品的感兴趣程度;

损失建立模块803,用于根据所述感兴趣程度构建训练损失,其中,所述训练损失与所述样本用户对所述正样本产品的感兴趣程度负相关,且与所述样本用户对所述负样本产品的感兴趣程度正相关;

模型确定模块804,用于根据所述训练损失调整所述原始训练模型,得到产品推荐模型。

在一种可能的实施例中,所述装置还包括:

分布获取模块,用于获取样本用户在各原始特征维度上的样本特征分布以及跨时间测试用户在各所述原始特征维度上的跨时间特征分布,其中,所述跨时间测试用户为在跨时间窗口内拥有正样本产品的用户,所述跨时间窗口与历史时间窗口不重叠,所述历史时间窗口为所述样本用户拥有正样本产品的时间窗口;

特征筛选模块,用于从所述原始特征维度中筛除所述样本特征分布与所述跨时间特征分布差异满足预设条件的特征维度,得到目标特征维度;

所述特征获取模块801,具体用于获取样本用户在所述目标特征维度上的用户特征。

在一种可能的实施例中,所述特征筛选模块,包括:

第一评估子模块,用于通过稳定性指标评估所述样本特征分布和所述跨时间特征分布在所述原始特征维度上的分布差异,得到第一评估结果;

第一特征子模块,用于根据所述第一评估结果筛除所述原始特征维度中所述样本特征分布与所述跨时间特征分布差异满足第一预设条件的特征维度,得到第一特征维度;

第二评估子模块,用于通过对抗验证方式评估所述样本特征分布和所述跨时间特征分布在所述第一特征维度上的分布差异,得到第二评估结果;

目标特征子模块,用于根据所述第二评估结果筛除所述第一特征维度中所述样本特征分布与所述跨时间特征分布差异满足第二预设条件的特征维度,得到目标特征维度。

在一种可能的实施例中,还包括:

验证获取模块,用于获取验证样本的用户特征、候选推荐产品中所述验证样本拥有的正样本产品,和与所述正样本产品类别相同且所述验证样本未拥有的负样本产品;

验证输出模块,用于将所述验证样本的用户特征输入至所述产品推荐模型,得到所述产品推荐模型输出的各所述验证样本对各所述候选推荐产品的感兴趣程度;

匹配确定模块,用于确定所述感兴趣程度与所述正样本产品和所述负样本产品的匹配程度;

验证结果模块,用于根据所述匹配程度验证所述产品推荐模型,得到验证结果。

在一种可能的实施例中,所述匹配确定模块,包括:

指标计算子模块,用于根据所述验证样本对各所述候选推荐产品的感兴趣程度统计AUC和/或KS指标;

第一匹配确定子模块,用于根据所述AUC和/或KS指标确定所述感兴趣程度与所述候选推荐产品中正样本产品和所述候选推荐产品中负样本产品的匹配程度。

在一种可能的实施例中,所述匹配确定模块,包括:

箱体分配子模块,用于根据感兴趣程度将所述候选推荐产品进行等频分箱,得到各箱体;

样本率确定子模块,用于统计每个箱体内所述正样本产品的正样本率和/或所述负样本产品的负样本率;

第二匹配确定子模块,确定所述正样本率和/或负样本率与所述箱体的匹配程度,作为所述感兴趣程度与所述正样本产品和所述负样本产品的匹配程度。

本公开的技术方案中,所涉及的用户个人信息的收集、存储、使用、加工、传输、提供和公开等处理,均符合相关法律法规的规定,且不违背公序良俗。

根据本公开的实施例,本公开还提供了一种电子设备、一种可读存储介质和一种计算机程序产品。

图9示出了可以用来实施本公开的实施例的示例电子设备900的示意性框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本公开的实现。

如图9所示,设备900包括计算单元901,其可以根据存储在只读存储器(ROM)902中的计算机程序或者从存储单元908加载到随机访问存储器(RAM)903中的计算机程序,来执行各种适当的动作和处理。在RAM 903中,还可存储设备900操作所需的各种程序和数据。计算单元901、ROM 902以及RAM 903通过总线904彼此相连。输入/输出(I/O)接口905也连接至总线904。

设备900中的多个部件连接至I/O接口905,包括:输入单元906,例如键盘、鼠标等;输出单元907,例如各种类型的显示器、扬声器等;存储单元908,例如磁盘、光盘等;以及通信单元909,例如网卡、调制解调器、无线通信收发机等。通信单元909允许设备900通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。

计算单元901可以是各种具有处理和计算能力的通用和/或专用处理组件。计算单元901的一些示例包括但不限于中央处理单元(CPU)、图形处理单元(GPU)、各种专用的人工智能(AI)计算芯片、各种运行机器学习模型算法的计算单元、数字信号处理器(DSP)、以及任何适当的处理器、控制器、微控制器等。计算单元901执行上文所描述的各个方法和处理,例如产品推荐方法和产品推荐模型的训练方法。例如,在一些实施例中,产品推荐方法和产品推荐模型的训练方法可被实现为计算机软件程序,其被有形地包含于机器可读介质,例如存储单元908。在一些实施例中,计算机程序的部分或者全部可以经由ROM 902和/或通信单元909而被载入和/或安装到设备900上。当计算机程序加载到RAM 903并由计算单元901执行时,可以执行上文描述的产品推荐方法和产品推荐模型的训练方法的一个或多个步骤。备选地,在其他实施例中,计算单元901可以通过其他任何适当的方式(例如,借助于固件)而被配置为执行产品推荐方法和产品推荐模型的训练方法。

本文中以上描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、芯片上系统的系统(SOC)、复杂可编程逻辑设备(CPLD)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。

用于实施本公开的方法的程序代码可以采用一个或多个编程语言的任何组合来编写。这些程序代码可以提供给通用计算机、专用计算机或其他可编程数据处理装置的处理器或控制器,使得程序代码当由处理器或控制器执行时使流程图和/或框图中所规定的功能/操作被实施。程序代码可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。

在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。

为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。

可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)和互联网。

计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,也可以为分布式系统的服务器,或者是结合了区块链的服务器。

应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本公开中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本公开公开的技术方案所期望的结果,本文在此不进行限制。

上述具体实施方式,并不构成对本公开保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本公开的精神和原则之内所作的修改、等同替换和改进等,均应包含在本公开保护范围之内。

相关技术
  • 一种个性化推荐方法、装置及电子设备
  • 一种信息推荐方法、装置及电子设备
  • 一种电子设备的输入方法、输入装置及电子设备
  • 一种电子设备、双屏电子设备的控制方法及装置
  • 一种产品推荐方法、装置及终端
  • 重定向广告产品推荐用户装置和服务提供装置、包括该重定向广告产品推荐用户装置和服务提供装置的广告产品推荐系统、其控制方法以及其中记录有计算机程序的记录介质
  • 一种产品的推荐方法、推荐装置及电子设备
技术分类

06120115564784