如何在不复制(或使用最少复制)5个多处理过程对象的情况下共享scipy.sparse.csc_matrix()?即使是numpy-shared方法似乎也需要复制整个数组,即便如此,我也不能将scipy.sparse转换为mp.Array().任何人都可以帮我指出正确的方向吗?
谢谢!
解决方法 我无法帮助您处理问题的多处理部分,但CSC稀疏矩阵只是三个numpy数组.您可以实例化另一个稀疏矩阵b,通过执行以下 *** 作来共享与稀疏矩阵相同的内存对象:import scipy.sparse as spsb = sps.csc_matrix((a.data,a.indices,a.indptr),shape=a.shape,copy=False)
a.data,a.indices和a.indptr是你想要在你的进程之间共享的三个numpy数组,如果你能这样做,那么在每个进程中实例化一个稀疏矩阵将是一个廉价的 *** 作.
总结以上是内存溢出为你收集整理的python – 在进程对象之间共享SciPy稀疏数组全部内容,希望文章能够帮你解决python – 在进程对象之间共享SciPy稀疏数组所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)