稀疏矩阵压缩存储:CSR

Posted MissSimple

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了稀疏矩阵压缩存储:CSR相关的知识,希望对你有一定的参考价值。

Compressed Sparse Row,CSR格式的列下标向量和数据值向量与COO格式(三元组)类似,在行下标表示上做了压缩。根据数据的排列规则,只需要指定在哪个数据换到下一行就行。

>>> col_idx = np.array([0,3,1,2,3,0,1,3])
>>> values = np.array([4,2,1,5,7,6,3,8])
 >>> row_ptr = np.array([0,2,3,5,8])
>>> csr_mat = scipy.sparse.csr_matrix((values,col_idx, row_ptr),shape=(4,4)).toarray()
>>> csr_mat
array([[4, 0, 0, 2],
       [0, 1, 0, 0],
       [0, 0, 5, 7],
       [6, 3, 0, 8]]) 
 

 技术分享

 

把非零数据排成一列,并从0开始建立索引,row_ptr指定在哪个索引位置进行换行。例如,稀疏矩阵的第二行是1,那么就在索引2处进行切割。

 技术分享

 

以上是关于稀疏矩阵压缩存储:CSR的主要内容,如果未能解决你的问题,请参考以下文章

稀疏矩阵压缩存储:CSR

如何对存储为“压缩稀疏行”的矩阵进行稀疏矩阵索引?

以压缩稀疏行格式 (csr_matrix) 对矩阵中的值取对数

稀疏矩阵存储格式总结+存储效率对比:COO,CSR,DIA,ELL,HYB

将 scipy 稀疏矩阵存储为 HDF5

稀疏矩阵的压缩与还原