热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python报错invalid_python运行报错RuntimeWarning:invalidvalueindouble_scalars

我就搞不懂了,为什么运行老是会报类似于RuntimeWarning:overflowencounteredinmultiply的这种错误,这个应该不是代

我就搞不懂了,为什么运行老是会报类似于RuntimeWarning: overflow encountered in multiply的这种错误,这个应该不是代码逻辑的问题吧

部分代码如下:

#!/usr/bin/env python

# -*- coding: utf-8 -*-

# @File : TrustMF.py

from baseclass.SocialRecommender import SocialRecommender

import numpy as np

from tool import config

class TrustMF(SocialRecommender):

def __init__(self, conf,trainingSet=None,testSet=None,relation=list(),fold='[1]'):

super(TrustMF, self).__init__(conf,trainingSet,testSet,relation,fold)

def initModel(self):

super(TrustMF, self).initModel()

self.Br = np.random.rand(self.dao.trainingSize()[0], self.k) # latent user matrix

self.Wr = np.random.rand(self.dao.trainingSize()[0], self.k) # latent item matrix

self.Vr = np.random.rand(self.dao.trainingSize()[1], self.k) # latent item matrix

self.Be = np.random.rand(self.dao.trainingSize()[0], self.k) # latent user matrix

self.We = np.random.rand(self.dao.trainingSize()[0], self.k) # latent item matrix

self.Ve = np.random.rand(self.dao.trainingSize()[1], self.k) # latent item matrix

def readConfiguration(self):

super(TrustMF, self).readConfiguration()

regular = config.LineConfig(self.config['reg.lambda'])

self.regB = float(regular['-b'])

self.regT = float(regular['-t'])

def printAlgorConfig(self):

super(TrustMF,self).printAlgorConfig()

print 'Regularization parameter: regT %.3f' % self.regT

print '=' * 80

def buildModel(self):

# If necessary, you can fix the parameter in ./config/Trust.conf

iteration = 0

while iteration

self.loss = 0

self.trusterModel()

self.trusteeModel()

iteration += 1

self.isConverged(iteration)

def trusterModel(self):

for entry in self.dao.trainingData:

u, i, r = entry

mbu = len(self.sao.getFollowees(u))

uid = self.dao.getUserId(u)

iid = self.dao.getItemId(i)

error = self.truserPredict(u, i) - r

nbu = len(self.dao.userRated(u)[0])

nvi = len(self.dao.itemRated(i)[0])

self.loss += error**2 + self.regB * ((mbu + nbu) * self.Br[uid].dot(self.Br[uid]) + nvi * self.Vr[iid].dot(self.Vr[iid]))

self.Vr[iid] = self.Vr[iid] - self.lRate * (error * self.Br[uid] + self.regB * nvi * self.Vr[iid])

relations = self.sao.getFollowees(u)

if len(relations)!=0:

for followee in relations.iterkeys():

weight = relations[followee]

uf = self.dao.getUserId(followee)

if uf != -1 and self.dao.containsUser(followee): # followee is in rating set

error1 = self.Br[uid].dot(self.Wr[uf]) - weight

mwk = len(self.sao.getFollowers(followee))

self.loss += self.regT * error1**2 + self.regB * mwk * self.Wr[uf].dot(self.Wr[uf])

self.Br[uid] = self.Br[uid] - self.lRate * (error * self.Vr[iid] + self.regB * (mbu + nbu) * self.Br[uid] + self.regT * (self.Br[uid].dot(self.Wr[uf]) - weight) * self.Wr[uf])

self.Wr[uf] = self.Wr[uf] - self.lRate * (self.regT * error1 * self.Br[uid] + self.regB * mwk * self.Wr[uf])

def trusteeModel(self):

for entry in self.dao.trainingData:

u, i, r = entry

mwu = len(self.sao.getFollowers(u))

uid = self.dao.getUserId(u)

iid = self.dao.getItemId(i)

error = self.truseePredict(u, i) - r

nwu = len(self.dao.userRated(u)[0])

nvi = len(self.dao.itemRated(i)[0])

self.loss += error**2 + self.regB * ((mwu + nwu) * self.We[uid].dot(self.We[uid]) + nvi * self.Ve[iid].dot(self.Ve[iid]))

self.Ve[iid] = self.Ve[iid] - self.lRate * (error * self.We[uid] + self.regB * nvi * self.Ve[iid])

relations = self.sao.getFollowers(u)

if len(relations) != 0:

for follower in relations.iterkeys():

weight = relations[follower]

uf = self.dao.getUserId(follower)

if uf != -1 and self.dao.containsUser(follower): # follower is in rating set

error1 = self.Be[uf].dot(self.We[uid]) - weight

mbk = len(self.sao.getFollowees(follower))

self.loss += self.regT * error1**2 + self.regB * mbk * self.Be[uf].dot(self.Be[uf])

self.We[uid] = self.We[uid] - self.lRate * (error * self.Vr[iid] + self.regB * (mwu + nwu) * self.We[uid] + self.regT * error1 * self.Be[uf])

self.Be[uf] = self.Be[uf] - self.lRate * (self.regT * error1 * self.We[uid] + self.regB * mbk * self.Be[uf])

def truserPredict(self, u, i):

if self.dao.containsUser(u) and self.dao.containsItem(i):

u = self.dao.getUserId(u)

i = self.dao.getItemId(i)

return self.Br[u].dot(self.Vr[i])

else:

return self.dao.globalMean

def truseePredict(self, u, i):

if self.dao.containsUser(u) and self.dao.containsItem(i):

u = self.dao.getUserId(u)

i = self.dao.getItemId(i)

return self.We[u].dot(self.Ve[i])

else:

return self.dao.globalMean

def predict(self, u, i):

if self.dao.containsUser(u) and self.dao.containsItem(i):

u = self.dao.getUserId(u)

i = self.dao.getItemId(i)

return (self.Br[u] + self.We[u]).dot(self.Vr[i] + self.Ve[i]) * 0.25

else:

return self.dao.globalMean

我就写了个trustMF方法,用到梯度下降法,就给我报一大堆runtimeerror,我真的不知道到底哪里出错了

报错如下:

C:\Users\123\Documents\GitHub\RecQ\algorithm\rating\TrustMF.py:65: RuntimeWarning: overflow encountered in multiply

self.Br[uid] = self.Br[uid] - self.lRate * (error * self.Vr[iid] + self.regB * (mbu + nbu) * self.Br[uid] + self.regT * (self.Br[uid].dot(self.Wr[uf]) - weight) * self.Wr[uf])

C:\Users\123\Documents\GitHub\RecQ\algorithm\rating\TrustMF.py:65: RuntimeWarning: invalid value encountered in add

self.Br[uid] = self.Br[uid] - self.lRate * (error * self.Vr[iid] + self.regB * (mbu + nbu) * self.Br[uid] + self.regT * (self.Br[uid].dot(self.Wr[uf]) - weight) * self.Wr[uf])

C:\Users\123\Documents\GitHub\RecQ\algorithm\rating\TrustMF.py:64: RuntimeWarning: invalid value encountered in double_scalars

self.loss += self.regT * error1**2 + self.regB * mwk * self.Wr[uf].dot(self.Wr[uf])

C:\Users\123\Documents\GitHub\RecQ\algorithm\rating\TrustMF.py:54: RuntimeWarning: invalid value encountered in double_scalars

self.loss += error**2 + self.regB * ((mbu + nbu) * self.Br[uid].dot(self.Br[uid]) + nvi * self.Vr[iid].dot(self.Vr[iid]))

求解,在线等



推荐阅读
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • Python + Pytest 接口自动化测试中 Token 关联登录的实现方法
    本文将深入探讨 Python 和 Pytest 在接口自动化测试中如何实现 Token 关联登录,内容详尽、逻辑清晰,旨在帮助读者掌握这一关键技能。 ... [详细]
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 本文介绍如何使用布局文件在Android应用中排列多行TextView和Button,使其占据屏幕的特定比例,并提供示例代码以帮助理解和实现。 ... [详细]
  • 使用Pandas高效读取SQL脚本中的数据
    本文详细介绍了如何利用Pandas直接读取和解析SQL脚本,提供了一种高效的数据处理方法。该方法适用于各种数据库导出的SQL脚本,并且能够显著提升数据导入的速度和效率。 ... [详细]
  • 开发笔记:2020 BJDCTF Re encode
    开发笔记:2020 BJDCTF Re encode ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 黑马头条项目:Vue 文章详情模块与交互功能实现
    本文详细介绍了如何在黑马头条项目中配置文章详情模块的路由、获取和展示文章详情数据,以及实现关注、点赞、不喜欢和评论功能。通过这些步骤,您可以全面了解如何开发一个完整的前端文章详情页面。 ... [详细]
  • 本文探讨了如何在Classic ASP中实现与PHP的hash_hmac('SHA256', $message, pack('H*', $secret))函数等效的哈希生成方法。通过分析不同实现方式及其产生的差异,提供了一种使用Microsoft .NET Framework的解决方案。 ... [详细]
author-avatar
zws3504075
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有