加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

Python Numpy TypeError:输入类型不支持ufunc’isfinite’

发布时间:2020-12-20 11:56:01 所属栏目:Python 来源:网络整理
导读:这是我的代码: def topK(dataMat,sensitivity): meanVals = np.mean(dataMat,axis=0) meanRemoved = dataMat - meanVals covMat = np.cov(meanRemoved,rowvar=0) eigVals,eigVects = np.linalg.eig(np.mat(covMat)) 我在上面最后一行的标题中得到了错误.我
这是我的代码:

def topK(dataMat,sensitivity):
    meanVals = np.mean(dataMat,axis=0)
    meanRemoved = dataMat - meanVals
    covMat = np.cov(meanRemoved,rowvar=0)
    eigVals,eigVects = np.linalg.eig(np.mat(covMat))

我在上面最后一行的标题中得到了错误.我怀疑与数据类型有关,因此,这是Spyder中Variable Explorer中变量和数据类型的图像:

enter image description here

我已经尝试将np.linalg.eig(np.mat(covMat))更改为np.linalg.eig(np.array(np.mat(covMat)))和np.linalg.eig(np.array(covMat) )),没有任何作用.有任何想法吗? (一个例子会很棒!)

解决方法

你的数组有一个dtype的对象,但这应该是一些浮点dtype.使用例如

covMat = np.array(covMat,dtype=float)

转换dtype

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读