发明内容
但是,基于逻辑回归模型和多层神经网络的预测用户购买商品行为的方法,没有考虑到用户商品购买序列之间的相关性,比如用户在t时刻买完奶粉,t+1时刻很有可能去买奶瓶,因此,存在准确度较低的缺陷;基于递归神经网络的预测用户购买商品行为的方法,没有考虑到序列之间的时间差问题,比如在t时刻的时候,t-1时刻是5年前购买记录,那就完全没有必要考虑t-1时刻与t时刻之间购买的相关性,因此,这种方法也存在准确度较低的缺陷,此外,基于递归神经网络的预测用户购买商品行为的方法在预测用户购买商品行为时仅仅考虑商品特征向量序列G,没有考虑用户的特征,而不同特征的用户对于其购买商品行为也会有较大影响,因此,现有技术中预测用户购买商品行为的方法存在准确度较低的缺陷,这是非常令人烦恼的过程。
为此,非常需要一种改进的预测用户购买商品行为的方法,解决现有技术中存在的准确度较低的缺陷。
在本上下文中,本发明的实施方式期望提供一种预测用户购买商品行为的方法和装置。
在本发明实施方式的第一方面中,提供了一种预测用户购买商品行为的方法,包括:
获取用户的商品购买序列S、商品购买序列S所对应的购买时间序列T和商品特征向量序列G、以及用户特征向量U;
针对所述购买时间序列T中的每一个t时刻,分别执行下述步骤:
对所述用户特征向量U进行线性处理和非线性处理以得到用户隐节点向量H(U)t;
确定第一特征向量It,所述第一特征向量It根据Gt与零向量或者H(G)t-1拼接得到,所述Gt为在所述t时刻购买的商品的商品特征向量,所述零向量的维度为K1维度,所述K1维度为商品隐节点向量H(G)t的维度;所述H(G)t-1表示在与所述t时刻相邻的前一个时刻得到的商品隐节点向量;
对所述第一特征向量It进行线性处理和非线性处理以得到商品隐节点向量H(G)t;
根据所述用户隐节点向量H(U)t和所述商品隐节点向量H(G)t拼接得到的第二特征向量Ht,并对所述第二特征向量Ht进行处理,最终得到输出节点向量Ot;所述输出节点向量Ot表示所述用户在所述t时刻之后购买商品的概率。
在一个实施例中,根据本发明的上述实施例所述的方法,所述H(U)t满足如下规则:
其中,所述W1为第一线性层权重矩阵,所述第一线性层权重矩阵的维度为K2*K3,所述K2为所述用户特征向量U的维度,所述K3为所述用户隐节点向量H(U)t的维度。
在一些实施例中,根据本发明的上述任一实施例所述的方法,其中确定第一特征向量It的步骤包括:
根据T1和T2确定第一特征向量It;所述T1为在所述t时刻购买商品的实际时间点,所述T2为在与所述t时刻相邻的前一个时刻购买商品的实际时间点;
若(所述T1-所述T2)的差值大于时间阈值或者t=1,所述第一特征向量It根据Gt与零向量拼接得到;若(所述T1-所述T2)的差值小于或者等于所述时间阈值,所述第一特征向量It根据所述Gt与H(G)t-1拼接得到。上文中的t=1表示该t时刻是所述购买时间序列T中的第一个时刻。
在一些实施例中,根据本发明的上述任一实施例所述的方法,所述H(G)t满足如下规则:
其中,所述W2为第二线性层权重矩阵,所述第二线性层权重矩阵的维度为(K4+K1)*K1所述K4为所述商品特征向量序列G中的任意一商品特征向量Gt的维度。
在一些实施例中,根据本发明的上述任一实施例所述的方法,所述Ot满足如下规则:
其中,所述n为所述商品购买序列S中的元素个数,所述W3为第三线性层权重矩阵,所述第三线性层权重矩阵的维度为(K1+K3)*K5,所述K3为所述用户隐节点向量H(U)t的维度,所述K5位所述输出节点向量Ot的维度。
在一些实施例中,根据本发明的上述任一实施例所述的方法,其中对所述第二特征向量Ht进行处理的步骤包括:
对所述第二特征向量Ht进行线性处理和非线性处理。
在一些实施例中,根据本发明的上述任一实施例所述的方法,所述方法还包括:
确定N个商品购买样本序列M;
针对所述N个商品购买样本序列M中的每一个商品购买样本序列M,确定与该商品购买样本序列M对应的购买时间样本序列P、商品特征向量样本序列Q及用户特征向量样本R;
根据所有商品购买样本序列M,及对应的购买时间样本序列P、商品特征向量样本序列Q及用户特征向量样本R,预测所述W1、所述W2和所述W3中的至少一种。
在本发明实施方式的第二方面中,提供了一种预测用户购买商品行为的装置,包括:
获取单元,用于获取用户的商品购买序列S、商品购买序列S所对应的购买时间序列T和商品特征向量序列G、以及用户特征向量U;
处理单元,用于针对所述购买时间序列T中的每一个t时刻,分别执行下述步骤:对所述用户特征向量U进行线性处理和非线性处理以得到用户隐节点向量H(U)t;
确定单元,用于确定第一特征向量It,所述第一特征向量It根据Gt与零向量或者H(G)t-1拼接得到,所述Gt为在所述t时刻购买的商品的商品特征向量,所述零向量的维度为K1维度,所述K1维度为商品隐节点向量H(G)t的维度;所述H(G)t-1表示在与所述t时刻相邻的前一个时刻得到的商品隐节点向量;
所述处理单元还用于,对所述第一特征向量It进行线性处理和非线性处理以得到商品隐节点向量H(G)t;
拼接单元,用于根据所述用户隐节点向量H(U)t和所述商品隐节点向量H(G)t拼接得到的第二特征向量Ht;
所述处理单元还用于,对所述第二特征向量Ht进行处理,最终得到输出节点向量Ot;所述输出节点向量Ot表示所述用户在所述t时刻之后购买商品的概率。
在一个实施例中,根据本发明的上述实施例所述的装置,所述H(U)t满足如下规则:
其中,所述W1为第一线性层权重矩阵,所述第一线性层权重矩阵的维度为K2*K3,所述K2为所述用户特征向量U的维度,所述K3为所述用户隐节点向量H(U)t的维度。
在一些实施例中,根据本发明的上述任一实施例所述的装置,其中所述确定单元确定第一特征向量It时具体为:
根据T1和T2确定第一特征向量It;所述T1为在所述t时刻购买商品的实际时间点,所述T2为在与所述t时刻相邻的前一个时刻购买商品的实际时间点;
若(所述T1-所述T2)的差值大于时间阈值或者t=1,所述第一特征向量It根据Gt与零向量拼接得到;若(所述T1-所述T2)的差值小于或者等于所述时间阈值,所述第一特征向量It根据所述Gt与H(G)t-1拼接得到。上文中的t=1表示该t时刻是所述购买时间序列T中的第一个时刻。
在一些实施例中,根据本发明的上述任一实施例所述的装置,所述H(G)t满足如下规则:
其中,所述W2为第二线性层权重矩阵,所述第二线性层权重矩阵的维度为(K4+K1)*K1所述K4为所述商品特征向量序列G中的任意一商品特征向量Gt的维度。
在一些实施例中,根据本发明的上述任一实施例所述的装置,所述Ot满足如下规则:
其中,所述n为所述商品购买序列S中的元素个数,所述W3为第三线性层权重矩阵,所述第三线性层权重矩阵的维度为(K1+K3)*K5,所述K3为所述用户隐节点向量H(U)t的维度,所述K5位所述输出节点向量Ot的维度。
在一些实施例中,根据本发明的上述任一实施例所述的装置,其中所述处理单元对所述第二特征向量Ht进行处理时具体为:
对所述第二特征向量Ht进行线性处理和非线性处理。
在一些实施例中,根据本发明的上述任一实施例所述的装置,所述确定单元还用于,确定N个商品购买样本序列M;针对所述N个商品购买样本序列M中的每一个商品购买样本序列M,确定与该商品购买样本序列M对应的购买时间样本序列P、商品特征向量样本序列Q及用户特征向量样本R;
还包括预测单元,用于根据所有商品购买样本序列M,及对应的购买时间样本序列P、商品特征向量样本序列Q及用户特征向量样本R,预测所述W1、所述W2和所述W3中的至少一种。
本发明的实施方式提供了一种预测用户购买商品行为的方法及装置:获取用户的商品购买序列S、商品购买序列S所对应的购买时间序列T和商品特征向量序列G、以及用户特征向量U;针对所述购买时间序列T中的每一个t时刻,分别执行下述步骤:对所述用户特征向量U进行线性处理和非线性处理以得到用户隐节点向量H(U)t;确定第一特征向量It,所述第一特征向量It根据Gt与零向量或者H(G)t-1拼接得到,所述Gt为在所述t时刻购买的商品的商品特征向量,所述零向量的维度为K1维度,所述K1维度为商品隐节点向量H(G)t的维度;所述H(G)t-1表示在与所述t时刻相邻的前一个时刻得到的商品隐节点向量;对所述第一特征向量It进行线性处理和非线性处理以得到商品隐节点向量H(G)t;根据所述用户隐节点向量H(U)t和所述商品隐节点向量H(G)t拼接得到的第二特征向量Ht,并对所述第二特征向量Ht进行处理,最终得到输出节点向量Ot;所述输出节点向量Ot表示所述用户在所述t时刻之后购买商品的概率,该方案中,预测用户购买商品行为时,不仅要考虑商品特征向量序列G,还考虑用户特征向量U,因此,解决了现有技术中存在的准确度较低的缺陷。
进一步的,本发明实施例中,第一特征向量It是根据T1和T2确定的;所述T1为在所述t时刻购买商品的实际时间点,所述T2为在与所述t时刻相邻的前一个时刻购买商品的实际时间点,即引入截断时间差,对购买序列中的时间相关有效性进行判断,进一步提高预测的准确度。
具体实施方式
下面将参考若干示例性实施方式来描述本发明的原理和精神。应当理解,给出这些实施方式仅仅是为了使本领域技术人员能够更好地理解进而实现本发明,而并非以任何方式限制本发明的范围。相反,提供这些实施方式是为了使本公开更加透彻和完整,并且能够将本公开的范围完整地传达给本领域的技术人员。
本领域技术技术人员知道,本发明的实施方式可以实现为一种***、装置、设备、方法或计算机程序产品。因此,本公开可以具体实现为以下形式,即:完全的硬件、完全的软件(包括固件、驻留软件、微代码等),或者硬件和软件结合的形式。
根据本发明的实施方式,提出了一种预测用户购买商品行为的方法和装置。
在本文中,附图中的任何元素数量均用于示例而非限制,以及任何命名都仅用于区分,而不具有任何限制含义。
下面参考本发明的若干代表性实施方式,详细阐释本发明的原理和精神。
发明概述
本发明人发现,采用如下方式的预测用户购买商品行为的方法可以提高预测的准确度:获取用户的商品购买序列S、商品购买序列S所对应的购买时间序列T和商品特征向量序列G、以及用户特征向量U;针对所述购买时间序列T中的每一个t时刻,分别执行下述步骤:对所述用户特征向量U进行线性处理和非线性处理以得到用户隐节点向量H(U)t;确定第一特征向量It,所述第一特征向量It根据Gt与零向量或者H(G)t-1拼接得到,所述Gt为在所述t时刻购买的商品的商品特征向量,所述零向量的维度为K1维度,所述K1维度为商品隐节点向量H(G)t的维度;所述H(G)t-1表示在与所述t时刻相邻的前一个时刻得到的商品隐节点向量;对所述第一特征向量It进行线性处理和非线性处理以得到商品隐节点向量H(G)t;根据所述用户隐节点向量H(U)t和所述商品隐节点向量H(G)t拼接得到的第二特征向量Ht,并对所述第二特征向量Ht进行处理,最终得到输出节点向量Ot;所述输出节点向量Ot表示所述用户在所述t时刻之后购买商品的概率,该方案中,预测用户购买商品行为时,不仅要考虑商品特征向量序列G,还考虑用户特征向量U,因此,解决了现有技术中存在的准确度较低的缺陷。
在介绍了本发明的基本原理之后,下面具体介绍本发明的各种非限制性实施方式。
应用场景总览
首先参考图1所示,本发明实施例所提供的预测用户购买商品行为的方法和装置所描述的方案可以应用于网易考拉海购(图1所示),或者网易云课堂,或者网易游戏中,当然,也可以用于其他网站,本发明不做具体限定。
示例性方法
下面结合图1的应用场景,参考图2来描述根据本发明示例性实施方式的用于预测用户购买商品行为的方法。需要注意的是,上述应用场景仅是为了便于理解本发明的精神和原理而示出,本发明的实施方式在此方面不受任何限制。相反,本发明的实施方式可以应用于适用的任何场景。
本领域技术人员可以理解,上面所说的应用场景仅是本发明的实施方式可以在其中得以实现的几个示例。本发明实施方式的适用范围不受任何限制。
图2示意性地示出了根据本发明实施方式的用于预测用户购买商品行为的方法20的流程示意图。如图2所示,该方法可以包括步骤200、210、220、230、240以及250。
该方法始于步骤200,获取用户的商品购买序列S、商品购买序列S所对应的购买时间序列T和商品特征向量序列G、以及用户特征向量U。
本发明实施例中,用户特征向量U可以有多种形式:例如,可以是描述用户年龄、性别、兴趣、爱好中的至少一种文本处理特征向量;或者也可以是根据音频数据提取的语音特征向量,上述只是用户特征向量U的几种具体形式,实际应用中,并不限定于上述几种方式。
本发明实施例中,商品特征向量序列G可以有多种形式:例如,可以是描述商品的图像向量,或者,也可以是根据商品图像向量提取的图像特征,如LBP(Local BinaryPatterns,局部二值模式)、HOG(Histogram of Oriented Gradient,方向梯度直方图)等特征,或者,也可以是描述商品属性的文本处理特征向量,上述只是用户特征向量U的几种具体形式,实际应用中,并不限定于上述几种方式。
在上述步骤200之后,还可以执行步骤210,其中针对所述购买时间序列T中的每一个t时刻,分别执行下述步骤。
本发明实施例中,t可以是实际时间点,也可以是时间序列序号,在此不做具体限定。
在上述步骤210之后,还可以执行步骤220,其中对所述用户特征向量U进行线性处理和非线性处理以得到用户隐节点向量H(U)t。
本发明实施例中,可选地,所述H(U)t满足如下规则:
其中,所述W1为第一线性层权重矩阵,所述第一线性层权重矩阵的维度为K2*K3,所述K2为所述用户特征向量U的维度,所述K3为所述用户隐节点向量H(U)t的维度。
在上述步骤220之后,还可以进一步的执行步骤230,其中确定第一特征向量It,所述第一特征向量It根据Gt与零向量或者H(G)t-1拼接得到,所述Gt为在所述t时刻购买的商品的商品特征向量,所述零向量的维度为K1维度,所述K1维度为商品隐节点向量H(G)t的维度;所述H(G)t-1表示在与所述t时刻相邻的前一个时刻得到的商品隐节点向量。
本发明实施例中,可选地,其中确定第一特征向量It的步骤包括:
根据T1和T2确定第一特征向量It;所述T1为在所述t时刻购买商品的实际时间点,所述T2为在与所述t时刻相邻的前一个时刻购买商品的实际时间点;
若(所述T1-所述T2)的差值大于时间阈值或者t=1,所述第一特征向量It根据Gt与零向量拼接得到;若(所述T1-所述T2)的差值小于或者等于所述时间阈值,所述第一特征向量It根据所述Gt与H(G)t-1拼接得到。
上文中的t=1表示该t时刻是所述购买时间序列T中的第一个时刻。
本发明实施例中,第一特征向量It是根据T1和T2确定的;所述T1为在所述t时刻购买商品的实际时间点,所述T2为在与所述t时刻相邻的前一个时刻购买商品的实际时间点,即引入截断时间差,对购买序列中的时间相关有效性进行判断,进一步提高预测的准确度。
在上述步骤230后,还可以执行步骤240,其中对所述第一特征向量It进行线性处理和非线性处理以得到商品隐节点向量H(G)t。
本发明实施例中,可选地,所述H(G)t满足如下规则:
其中,所述W2为第二线性层权重矩阵,所述第二线性层权重矩阵的维度为(K4+K1)*K1所述K4为所述商品特征向量序列G中的任意一商品特征向量Gt的维度。
在上述步骤240之后,还可以执行步骤250,其中根据所述用户隐节点向量H(U)t和所述商品隐节点向量H(G)t拼接得到的第二特征向量Ht,并对所述第二特征向量Ht进行处理,最终得到输出节点向量Ot;所述输出节点向量Ot表示所述用户在所述t时刻之后购买商品的概率。
本发明实施例中,可选地,所述Ot满足如下规则:
其中,所述n为所述商品购买序列S中的元素个数,所述W3为第三线性层权重矩阵,所述第三线性层权重矩阵的维度为(K1+K3)*K5,所述K3为所述用户隐节点向量H(U)t的维度,所述K5位所述输出节点向量Ot的维度。
本发明实施例中,Ot的每个维度代表每种商品,每个维度的数值代表预测到的购买该商品的概率。
本发明实施例中,步骤250中其中对所述第二特征向量Ht进行处理的步骤包括:
对所述第二特征向量Ht进行线性处理和非线性处理。
本发明实施例中,还要训练得到W1、所述W2和所述W3,因此,还包括如下操作:
确定N个商品购买样本序列M;
针对所述N个商品购买样本序列M中的每一个商品购买样本序列M,确定与该商品购买样本序列M对应的购买时间样本序列P、商品特征向量样本序列Q及用户特征向量样本R;
根据所有商品购买样本序列M,及对应的购买时间样本序列P、商品特征向量样本序列Q及用户特征向量样本R,预测所述W1、所述W2和所述W3中的至少一种。
本发明实施例中,上述描述的N个商品购买样本序列M中的任意两个不同的商品购买样本序列M可以不同。
本发明实施例中,对每一个商品购买样本序列M,将所有商品购买样本序列M,及对应的购买时间样本序列P、商品特征向量样本序列Q及用户特征向量样本R,输入递归神经网络模型,并计算误差信息。误差信息根据BPTT(Back Propagation Through Time,反向传播算法)并进行反向传播计算,并相应更新相应层的W1、所述W2和所述W3。反复执行K次上述计算过程,当最终输出的误差值小于阈值时终止迭代。
本发明的实施方式提供了一种预测用户购买商品行为的方法及装置:获取用户的商品购买序列S、商品购买序列S所对应的购买时间序列T和商品特征向量序列G、以及用户特征向量U;针对所述购买时间序列T中的每一个t时刻,分别执行下述步骤:对所述用户特征向量U进行线性处理和非线性处理以得到用户隐节点向量H(U)t;确定第一特征向量It,所述第一特征向量It根据Gt与零向量或者H(G)t-1拼接得到,所述Gt为在所述t时刻购买的商品的商品特征向量,所述零向量的维度为K1维度,所述K1维度为商品隐节点向量H(G)t的维度;所述H(G)t-1表示在与所述t时刻相邻的前一个时刻得到的商品隐节点向量;对所述第一特征向量It进行线性处理和非线性处理以得到商品隐节点向量H(G)t;根据所述用户隐节点向量H(U)t和所述商品隐节点向量H(G)t拼接得到的第二特征向量Ht,并对所述第二特征向量Ht进行处理,最终得到输出节点向量Ot;所述输出节点向量Ot表示所述用户在所述t时刻之后购买商品的概率,该方案中,预测用户购买商品行为时,不仅要考虑商品特征向量序列G,还考虑用户特征向量U,因此,解决了现有技术中存在的准确度较低的缺陷。
进一步的,本发明实施例中,第一特征向量It是根据T1和T2确定的;所述T1为在所述t时刻购买商品的实际时间点,所述T2为在与所述t时刻相邻的前一个时刻购买商品的实际时间点,即引入截断时间差,对购买序列中的时间相关有效性进行判断,进一步提高预测的准确度。
示例性设备
在介绍了本发明示例性实施方式的方法之后,接下来,参考图3对本发明示例性实施方式的用于预测用户购买商品行为的装置进行说明。
图3示意性地示出了根据本发明实施方式的用于预测用户购买商品行为的装置30的示意图。如图3所示,该装置30可以包括:
获取单元300,用于获取用户的商品购买序列S、商品购买序列S所对应的购买时间序列T和商品特征向量序列G、以及用户特征向量U;
处理单元310,用于针对所述购买时间序列T中的每一个t时刻,分别执行下述步骤:对所述用户特征向量U进行线性处理和非线性处理以得到用户隐节点向量H(U)t;
确定单元320,用于确定第一特征向量It,所述第一特征向量It根据Gt与零向量或者H(G)t-1拼接得到,所述Gt为在所述t时刻购买的商品的商品特征向量,所述零向量的维度为K1维度,所述K1维度为商品隐节点向量H(G)t的维度;所述H(G)t-1表示在与所述t时刻相邻的前一个时刻得到的商品隐节点向量;
所述处理单元310还用于,对所述第一特征向量It进行线性处理和非线性处理以得到商品隐节点向量H(G)t;
拼接单元330,用于根据所述用户隐节点向量H(U)t和所述商品隐节点向量H(G)t拼接得到的第二特征向量Ht;
所述处理单元310还用于,对所述第二特征向量Ht进行处理,最终得到输出节点向量Ot;所述输出节点向量Ot表示所述用户在所述t时刻之后购买商品的概率。
本发明实施例中,获取单元300获取的用户特征向量U可以有多种形式:例如,可以是描述用户年龄、性别、兴趣、爱好中的至少一种文本处理特征向量;或者也可以是根据音频数据提取的语音特征向量,上述只是用户特征向量U的几种具体形式,实际应用中,并不限定于上述几种方式。
本发明实施例中,获取单元300获取的商品特征向量序列G可以有多种形式:例如,可以是描述商品的图像向量,或者,也可以是根据商品图像向量提取的图像特征,如LBP(Local Binary Patterns,局部二值模式)、HOG(Histogram of Oriented Gradient,,方向梯度直方图)等特征,或者,也可以是描述商品属性的文本处理特征向量,上述只是用户特征向量U的几种具体形式,实际应用中,并不限定于上述几种方式。
本发明实施例中,可选地,处理单元310处理得到的所述H(U)t满足如下规则:
其中,所述W1为第一线性层权重矩阵,所述第一线性层权重矩阵的维度为K2*K3,所述K2为所述用户特征向量U的维度,所述K3为所述用户隐节点向量H(U)t的维度。
本发明实施例中,其中所述确定单元320确定第一特征向量It时具体为:
根据T1和T2确定第一特征向量It;所述T1为在所述t时刻购买商品的实际时间点,所述T2为在与所述t时刻相邻的前一个时刻购买商品的实际时间点;
若(所述T1-所述T2)的差值大于时间阈值或者t=1,所述第一特征向量It根据Gt与零向量拼接得到;若(所述T1-所述T2)的差值小于或者等于所述时间阈值,所述第一特征向量It根据所述Gt与H(G)t-1拼接得到。
上文中的t=1表示该t时刻是所述购买时间序列T中的第一个时刻。
本发明实施例中,确定单元320确定第一特征向量It时是根据T1和T2确定的;所述T1为在所述t时刻购买商品的实际时间点,所述T2为在与所述t时刻相邻的前一个时刻购买商品的实际时间点,即引入截断时间差,对购买序列中的时间相关有效性进行判断,进一步提高预测的准确度。
本发明实施例中,t可以是实际时间点,也可以是时间序列序号,在此不做具体限定。
本发明实施例中,可选地,处理单元310处理得到的所述H(G)t满足如下规则:
其中,所述W2为第二线性层权重矩阵,所述第二线性层权重矩阵的维度为(K4+K1)*K1所述K4为所述商品特征向量序列G中的任意一商品特征向量Gt的维度。
本发明实施例中,可选地,处理单元310处理得到的所述Ot满足如下规则:
其中,所述n为所述商品购买序列S中的元素个数,所述W3为第三线性层权重矩阵,所述第三线性层权重矩阵的维度为(K1+K3)*K5,所述K3为所述用户隐节点向量H(U)t的维度,所述K5位所述输出节点向量Ot的维度。
本发明实施例中,Ot的每个维度代表每种商品,每个维度的数值代表预测到的购买该商品的概率。
本发明实施例中,可选地,其中所述处理单元310对所述第二特征向量Ht进行处理时具体为:
对所述第二特征向量Ht进行线性处理和非线性处理。
本发明实施例中,还要训练得到W1、所述W2和所述W3,因此,所述确定单元320还用于,确定N个商品购买样本序列M;针对所述N个商品购买样本序列M中的每一个商品购买样本序列M,确定与该商品购买样本序列M对应的购买时间样本序列P、商品特征向量样本序列Q及用户特征向量样本R;
还包括预测单元340,用于根据所有商品购买样本序列M,及对应的购买时间样本序列P、商品特征向量样本序列Q及用户特征向量样本R,预测所述W1、所述W2和所述W3中的至少一种。
本发明实施例中,上述描述的N个商品购买样本序列M中的任意两个不同的商品购买样本序列M可以不同。
本发明实施例中,对每一个商品购买样本序列M,将所有商品购买样本序列M,及对应的购买时间样本序列P、商品特征向量样本序列Q及用户特征向量样本R,输入递归神经网络模型,并计算误差信息。误差信息根据BPTT算法并进行反向传播计算,并相应更新相应层的W1、所述W2和所述W3。反复执行K次上述计算过程,当最终输出的误差值小于阈值时终止迭代。
本发明的实施方式提供了一种预测用户购买商品行为的方法及装置:获取用户的商品购买序列S、商品购买序列S所对应的购买时间序列T和商品特征向量序列G、以及用户特征向量U;针对所述购买时间序列T中的每一个t时刻,分别执行下述步骤:对所述用户特征向量U进行线性处理和非线性处理以得到用户隐节点向量H(U)t;确定第一特征向量It,所述第一特征向量It根据Gt与零向量或者H(G)t-1拼接得到,所述Gt为在所述t时刻购买的商品的商品特征向量,所述零向量的维度为K1维度,所述K1维度为商品隐节点向量H(G)t的维度;所述H(G)t-1表示在与所述t时刻相邻的前一个时刻得到的商品隐节点向量;对所述第一特征向量It进行线性处理和非线性处理以得到商品隐节点向量H(G)t;根据所述用户隐节点向量H(U)t和所述商品隐节点向量H(G)t拼接得到的第二特征向量Ht,并对所述第二特征向量Ht进行处理,最终得到输出节点向量Ot;所述输出节点向量Ot表示所述用户在所述t时刻之后购买商品的概率,该方案中,预测用户购买商品行为时,不仅要考虑商品特征向量序列G,还考虑用户特征向量U,因此,解决了现有技术中存在的准确度较低的缺陷。
进一步的,本发明实施例中,第一特征向量It是根据T1和T2确定的;所述T1为在所述t时刻购买商品的实际时间点,所述T2为在与所述t时刻相邻的前一个时刻购买商品的实际时间点,即引入截断时间差,对购买序列中的时间相关有效性进行判断,进一步提高预测的准确度。
示例性设备
在介绍了本发明示例性实施方式的方法和装置之后,接下来,介绍根据本发明的另一示例性实施方式的用于预测用户购买商品行为的装置。
所属技术领域的技术人员能够理解,本发明的各个方面可以实现为***、方法或程序产品。因此,本发明的各个方面可以具体实现为以下形式,即:完全的硬件实施方式、完全的软件实施方式(包括固件、微代码等),或硬件和软件方面结合的实施方式,这里可以统称为“电路”、“模块”或“***”。
在一些可能的实施方式中,根据本发明的用于预测用户购买商品行为的装置可以至少包括至少一个处理单元、以及至少一个存储单元。其中,所述存储单元存储有程序代码,当所述程序代码被所述处理单元执行时,使得所述处理单元执行本说明书上述“示例性方法”部分中描述的根据本发明各种示例性实施方式的用于预测用户购买商品行为中的步骤。例如,所述处理单元可以执行如图2中所示的步骤200:获取用户的商品购买序列S、商品购买序列S所对应的购买时间序列T和商品特征向量序列G、以及用户特征向量U;步骤210:针对所述购买时间序列T中的每一个t时刻,分别执行下述步骤:步骤220:对所述用户特征向量U进行线性处理和非线性处理以得到用户隐节点向量H(U)t;步骤230:确定第一特征向量It,所述第一特征向量It根据Gt与零向量或者H(G)t-1拼接得到,所述Gt为在所述t时刻购买的商品的商品特征向量,所述零向量的维度为K1维度,所述K1维度为商品隐节点向量H(G)t的维度;所述H(G)t-1表示在与所述t时刻相邻的前一个时刻得到的商品隐节点向量;步骤240:对所述第一特征向量It进行线性处理和非线性处理以得到商品隐节点向量H(G)t;步骤250:根据所述用户隐节点向量H(U)t和所述商品隐节点向量H(G)t拼接得到的第二特征向量Ht,并对所述第二特征向量Ht进行处理,最终得到输出节点向量Ot;所述输出节点向量Ot表示所述用户在所述t时刻之后购买商品的概率。
下面参照图4来描述根据本发明的这种实施方式的用于预测用户购买商品行为的装置10。图4显示的用于预测用户购买商品行为的装置10仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图4所示,用于预测用户购买商品行为的装置10以通用计算设备的形式表现。用于预测用户购买商品行为的装置10的组件可以包括但不限于:上述至少一个处理单元16、上述至少一个存储单元28、连接不同***组件(包括存储单元28和处理单元16)的总线18。
总线18表示几类总线结构中的一种或多种,包括存储器总线或者存储器控制器、***总线、图形加速端口、处理器或者使用多种总线结构中的任意总线结构的局域总线。
存储单元28可以包括易失性存储器形式的可读介质,例如随机存取存储器(RAM)30和/或高速缓存存储器32,还可以进一步只读存储器(ROM)34。
存储单元28还可以包括具有一组(至少一个)程序模块42的程序/实用工具40,这样的程序模块42包括但不限于:操作***、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。
用于预测用户购买商品行为的装置10也可以与一个或多个外部设备14(例如键盘、指向设备、蓝牙设备等)通信,还可与一个或者多个使得用户能与该用于预测用户购买商品行为的装置10交互的设备通信,和/或与使得该用于预测用户购买商品行为的装置10能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口22进行。并且,用于预测用户购买商品行为的装置10还可以通过网络适配器20与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器20通过总线18与用于预测用户购买商品行为的装置10的其它模块通信。应当明白,尽管图中未示出,可以结合用于预测用户购买商品行为的装置10使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID***、磁带驱动器以及数据备份存储***等。
示例性程序产品
在一些可能的实施方式中,本发明的各个方面还可以实现为一种程序产品的形式,其包括程序代码,当所述程序产品在终端设备上运行时,所述程序代码用于使所述终端设备执行本说明书上述“示例性方法”部分中描述的根据本发明各种示例性实施方式的用于预测用户购买商品行为的方法中的步骤,例如,所述终端设备可以执行如图2中所示的步骤200:获取用户的商品购买序列S、商品购买序列S所对应的购买时间序列T和商品特征向量序列G、以及用户特征向量U;步骤210:针对所述购买时间序列T中的每一个t时刻,分别执行下述步骤:步骤220:对所述用户特征向量U进行线性处理和非线性处理以得到用户隐节点向量H(U)t;步骤230:确定第一特征向量It,所述第一特征向量It根据Gt与零向量或者H(G)t-1拼接得到,所述Gt为在所述t时刻购买的商品的商品特征向量,所述零向量的维度为K1维度,所述K1维度为商品隐节点向量H(G)t的维度;所述H(G)t-1表示在与所述t时刻相邻的前一个时刻得到的商品隐节点向量;步骤240:对所述第一特征向量It进行线性处理和非线性处理以得到商品隐节点向量H(G)t;步骤250:根据所述用户隐节点向量H(U)t和所述商品隐节点向量H(G)t拼接得到的第二特征向量Ht,并对所述第二特征向量Ht进行处理,最终得到输出节点向量Ot;所述输出节点向量Ot表示所述用户在所述t时刻之后购买商品的概率。
所述程序产品可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的***、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。
如图5所示,描述了根据本发明的实施方式的用于预测用户购买商品行为的程序产品50,其可以采用便携式紧凑盘只读存储器(CD-ROM)并包括程序代码,并可以在终端设备,例如个人电脑上运行。然而,本发明的程序产品不限于此,在本文件中,可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行***、装置或者器件使用或者与其结合使用。
可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了可读程序代码。这种传播的数据信号可以采用多种形式,包括——但不限于——电磁信号、光信号或上述的任意合适的组合。可读信号介质还可以是可读存储介质以外的任何可读介质,该可读介质可以发送、传播或者传输用于由指令执行***、装置或者器件使用或者与其结合使用的程序。
可读介质上包含的程序代码可以用任何适当的介质传输,包括——但不限于——无线、有线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言的任意组合来编写用于执行本发明操作的程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、C++等,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。
应当注意,尽管在上文详细描述中提及了用于预测用户购买商品行为的设备的若干装置或子装置,但是这种划分仅仅并非强制性的。实际上,根据本发明的实施方式,上文描述的两个或更多装置的特征和功能可以在一个装置中具体化。反之,上文描述的一个装置的特征和功能可以进一步划分为由多个装置来具体化。
此外,尽管在附图中以特定顺序描述了本发明方法的操作,但是,这并非要求或者暗示必须按照该特定顺序来执行这些操作,或是必须执行全部所示的操作才能实现期望的结果。附加地或备选地,可以省略某些步骤,将多个步骤合并为一个步骤执行,和/或将一个步骤分解为多个步骤执行。
虽然已经参考若干具体实施方式描述了本发明的精神和原理,但是应该理解,本发明并不限于所公开的具体实施方式,对各方面的划分也不意味着这些方面中的特征不能组合以进行受益,这种划分仅是为了表述的方便。本发明旨在涵盖所附权利要求的精神和范围内所包括的各种修改和等同布置。