python – Scipy稀疏 – 距离矩阵(Scikit或Scipy)
我试图在scikit-learn的DictVectorizer返回的Scipy稀疏矩阵上计算最近邻居聚类.但是,当我尝试使用scikit-learn计算距离矩阵时,我通过pairwise.euclidean_distances和pairwise.pairwise_distances使用’euclidean’距离得到错误消息.我的印象是scikit-learn可以计算这些距离矩阵. 我的矩阵非常稀疏,形状为:< 364402x223209稀疏矩阵类型< class'numpy.float64'> 我也在Scipy中尝试了诸如pdist和kdtree之类的方法,但是还收到了其他无法处理结果的错误. 任何人都可以请我指出一个有效地允许我计算距离矩阵和/或最近邻结果的解决方案吗? 一些示例代码:
错误:
同样,如果我跑:
我得到以下内容:
最后,在scikit-learn中运行NearestNeighbor会导致内存错误,使用:
最佳答案
首先,你不能使用稀疏矩阵的KDTree和pdist,你必须将它转换为密集(你的选择是否是你的选择):
第二,从the docs:
您可能想尝试’ball_tree’算法并查看它是否可以处理您的数据. (编辑:4S站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- python-2.7 – TypeError:预期序列或类似数组,得到估算器
- python – 如何在DataFrame中增加groupby中的行数
- 错误:输入’for’Python时没有可行的替代方案
- python – 登录Django和炮弹
- `with canvas:`(Python`with something()as x:`)如何隐式
- CentOS中使用virtualenv搭建python3环境
- 试图了解python csv .next()
- python – 是否有一个有意义的方法来使用发生器内的上下文管
- python – 为Matplotlib imshow()手动定义的轴标签
- python – 将变量传递到jinja导入或从父HTML文件中包含