ML之RS之MF:基于简单的张量分解MF算法进行打分和推荐

简介: ML之RS之MF:基于简单的张量分解MF算法进行打分和推荐

输出结果


先看结果

image.png





实现代码


#ML之RS之MF:基于简单的张量分解MF算法进行打分和推荐

import numpy

def matrix_factorization(R, P, Q, K, steps=5000, alpha=0.0002, beta=0.02):  #(迭代次数5000、步长,正则化系数)

   Q = Q.T

   for step in range(steps):

       for i in range(len(R)):

           for j in range(len(R[i])):

               if R[i][j] > 0:

                   eij = R[i][j] - numpy.dot(P[i,:],Q[:,j])

                   for k in range(K):

                       P[i][k] = P[i][k] + alpha * (2 * eij * Q[k][j] - beta * P[i][k])

                       Q[k][j] = Q[k][j] + alpha * (2 * eij * P[i][k] - beta * Q[k][j])

       eR = numpy.dot(P,Q)

       e = 0

       for i in range(len(R)):

           for j in range(len(R[i])):

               if R[i][j] > 0:

                   e = e + pow(R[i][j] - numpy.dot(P[i,:],Q[:,j]), 2)

                   for k in range(K):

                       e = e + (beta/2) * (pow(P[i][k],2) + pow(Q[k][j],2))

       if e < 0.001:

           break

   return P, Q.T

#读取user数据并用张量分解进行打分

#定义得分矩阵

R = [

    [5,3,0,1],

    [4,0,3,1],

    [1,1,0,5],

    [1,0,0,4],

    [0,1,5,4],

   ]

R = numpy.array(R)

N = len(R)

M = len(R[0])

K = 2  #两个因子

P = numpy.random.rand(N,K)

Q = numpy.random.rand(M,K)

nP, nQ = matrix_factorization(R, P, Q, K)

nR = numpy.dot(nP, nQ.T)

print(nP)

print("-----------------------------")

print(nQ)

print("-----------------------------")

print(nR)

print("-----------------------------")

print(R)

 

相关文章
|
3月前
|
并行计算 算法 计算机视觉
【MATLAB 】 EMD信号分解+模糊熵(近似熵)算法
【MATLAB 】 EMD信号分解+模糊熵(近似熵)算法
40 0
|
3月前
|
并行计算 算法 计算机视觉
【MATLAB 】 EEMD 信号分解+模糊熵(近似熵)算法
【MATLAB 】 EEMD 信号分解+模糊熵(近似熵)算法
36 0
|
3月前
|
并行计算 算法 计算机视觉
【MATLAB 】 CEEMD 信号分解+模糊熵(近似熵)算法
【MATLAB 】 CEEMD 信号分解+模糊熵(近似熵)算法
51 0
|
3月前
|
并行计算 算法 计算机视觉
【MATLAB 】 CEEMDAN 信号分解+模糊熵(近似熵)算法
【MATLAB 】 CEEMDAN 信号分解+模糊熵(近似熵)算法
79 0
|
3月前
|
编解码 算法 jenkins
【MATLAB 】 小波分解-ARIMA联合时序预测算法,科研创新优选算法
【MATLAB 】 小波分解-ARIMA联合时序预测算法,科研创新优选算法
53 0
|
3月前
|
编解码 并行计算 算法
【MATLAB 】 小波分解信号分解+模糊熵(近似熵)算法
【MATLAB 】 小波分解信号分解+模糊熵(近似熵)算法
20 0
|
3月前
|
并行计算 算法
【MATLAB 】 辛几何模态分解信号分解+模糊熵(近似熵)算法
【MATLAB 】 辛几何模态分解信号分解+模糊熵(近似熵)算法
49 0
|
3月前
|
并行计算 算法 计算机视觉
【MATLAB 】 EWT 信号分解+模糊熵(近似熵)算法
【MATLAB 】 EWT 信号分解+模糊熵(近似熵)算法
37 0
|
3月前
|
并行计算 算法 数据处理
【MATLAB 】 MODWT 信号分解+模糊熵(近似熵)算法
【MATLAB 】 MODWT 信号分解+模糊熵(近似熵)算法
24 0
|
3月前
|
并行计算 算法 计算机视觉
【MATLAB 】 VMD 信号分解+模糊熵(近似熵)算法
【MATLAB 】 VMD 信号分解+模糊熵(近似熵)算法
54 0