▶ 图片参考【http://www.bu.edu/pasi/files/2011/01/NathanBell1-10-1000.pdf】

▶ 各种系数矩阵的数据结构

● MAT,原始矩阵数据

 typedef struct          // 顺序格式
{
int row; // 行数
int col; // 列数
int count; // 非零元个数(用于转换,不用于计算)
format *data; // 元素的值
}
MAT;

●  Compressed Sparse Row(CSR),由非零值向量,各元素列号向量,各行首元在列号向量中的起始位置向量组成

 typedef struct
{
int row; // 行数
int col; // 列数
format *data; // 非零元的值
int *index; // 非零元的列号
int *ptr; // 每行首元在 index 中的下标,最后一个元素的值等于矩阵非零元个数
}
CSR;

● Compressed Sparse Column Format (CSC),类似 CSR,不过是列优先存储,实现暂时没写,留坑

 typedef struct
{
int row; // 行数
int col; // 列数
format *data; // 非零元的值
int *index; // 非零元的行号
int *ptr; // 每列首元在 index 中的下标,最后一个元素的值等于矩阵非零元个数
}
CSC;

●  ELLPACK(ELL),记录非零元的列号,然后把非零元素压缩到最左边。为了提高内存读取,我的 ELL 相当于将图中的两个矩阵进行了转置

 typedef struct
{
int row; // 行数,等于 MAT 格式非零元最多行的非零元个数
int col; // 列数,等于 MAT 格式的行数
int colOrigin; // 原列数,等于 MAT 格式的列数
format *data; // 非零元的值
int *index; // 元素在原矩阵中的列号
}
ELL;

●  Coordinate(COO),用行列坐标来记录每个非零元的位置

 typedef struct
{
int row; // 行数
int col; // 列数
int count; // 非零元个数
int *rowIndex; // 行向量
int *colIndex; // 列向量
format *data; // 元素的值
}
COO;

● Diagonal(DIA),相当于将矩阵的主对角线捋成一列,其他元素水平移动,然后砍掉所有元素均为零的列(即原矩阵中所有元素均为零的对角线),变换后矩阵行数不变,列数可能增大或减小

 typedef struct
{
int row; // 行数
int col; // 列数
int colOrigin; // 原列数
format *data; // 元素的值
int *index; // 原矩阵各对角线是否非零
}
DIA;

● Hybrid (HYB) ELL + COO,相当于先尽量 ELL,右边多出的部分砍下来用 COO 单独保存。实现暂时没写,留坑

● Skyline Matrix Storage Format,参考【https://software.intel.com/en-us/mkl-developer-reference-c-sparse-blas-skyline-matrix-storage-format】。实现暂时没写,留坑

■ 例如,下三角中,value 按行优先保存了主对角线及其左下部的元素,每行开头的零略掉但中间的零不省略,ptr 记录每行第一个非零元在 value 中的下标;上三角类似,但是按列优先排列元素。

● Block Sparse Row(BSR),参考【https://software.intel.com/en-us/mkl-developer-reference-c-sparse-blas-bsr-matrix-storage-format】,那个 4 向量的版本没太理解,3 向量的版本参考【http://www.cs.colostate.edu/~mcrob/toolbox/c+/sparse_matrix_compression.html】看懂了。实现暂时没写,留坑

■ 3 向量版本中,value 表示分块小矩阵的值,呈行优先排列,小矩阵元素展开成一维时内部要列优先排列(这里超出了 Mathtype 的最大宽度,所以没有展开),col_index 表示每个小矩阵起始列号,row_ptr 表示每行首个非零小矩阵在 col_index 中的下标

稀疏矩阵 part 1的更多相关文章

  1. [LeetCode] Sparse Matrix Multiplication 稀疏矩阵相乘

    Given two sparse matrices A and B, return the result of AB. You may assume that A's column number is ...

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

    http://www.cnblogs.com/xbinworld/p/4273506.html 稀疏矩阵是指矩阵中的元素大部分是0的矩阵,事实上,实际问题中大规模矩阵基本上都是稀疏矩阵,很多稀疏度在9 ...

  3. poj 3735 Training little cats 矩阵快速幂+稀疏矩阵乘法优化

    题目链接 题意:有n个猫,开始的时候每个猫都没有坚果,进行k次操作,g x表示给第x个猫一个坚果,e x表示第x个猫吃掉所有坚果,s x y表示第x个猫和第y个猫交换所有坚果,将k次操作重复进行m轮, ...

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

    稀疏矩阵是指矩阵中的元素大部分是0的矩阵,事实上,实际问题中大规模矩阵基本上都是稀疏矩阵,很多稀疏度在90%甚至99%以上.因此我们需要有高效的稀疏矩阵存储格式.本文总结几种典型的格式:COO,CSR ...

  5. C语言 稀疏矩阵 压缩 实现

    稀疏矩阵压缩存储的C语言实现 (GCC编译). /** * @brief C语言 稀疏矩阵 压缩 实现 * @author wid * @date 2013-11-04 * * @note 若代码存在 ...

  6. 三元组表压缩存储稀疏矩阵实现稀疏矩阵的快速转置(Java语言描述)

    三元组表压缩存储稀疏矩阵实现稀疏矩阵的快速转置(Java语言描述) 用经典矩阵转置算法和普通的三元组矩阵转置在时间复杂度上都是不乐观的.快速转置算法在增加适当存储空间后实现快速转置具体原理见代码注释部 ...

  7. 稀疏矩阵乘法加法等的java实现

    原创声明:本文系作者原创,转载请写明出处. 一.前言       前几天由于科研需要,一直在搞矩阵的稀疏表示的乘法,不过最近虽然把程序写出来了,还是无法处理大规模的矩阵(虽然已经是稀疏了).原因可能是 ...

  8. Matlab稀疏矩阵

    一.矩阵存储方式 MATLAB的矩阵有两种存储方式,完全存储方式和稀疏存储方式 1.完全存储方式 将矩阵的全部元素按列存储,矩阵中的全部零元素也存储到矩阵中. 2.稀疏存储方式 仅存储矩阵所有的非零元 ...

  9. matlab——sparse函数和full函数(稀疏矩阵和非稀疏矩阵转换)

    函数功能:生成稀疏矩阵 使用方法 :S = sparse(A) 将矩阵A转化为稀疏矩阵形式,即矩阵A中任何0元素被去除,非零元素及其下标组成矩阵S.如果A本身是稀疏的,sparse(S)返回S. S ...

  10. 稀疏矩阵coo_matrix的乘法

    稀疏矩阵的乘法在做基于n-gram的分类的时候还是相当有用的,但是由于网上资料太少,所以折腾了几天才算折腾出来. 首先scipy包里常见的稀疏矩阵有三种形式, coo_matrix, csr_matr ...

随机推荐

  1. 解题报告 『[USACO08NOV]Mixed Up Cows(状压动规)』

    原题地址 观察数据范围:4 ≤ N ≤ 16. 很明显,这是一道状压DP. 定义:dp[i][j]表示队尾为奶牛i,当前含奶牛的状态为j,共有多少组符合条件的队伍. 代码实现如下: #include ...

  2. JVM垃圾回收机制之对象回收算法

    前言 在前面的文章中,介绍了JVM内存模型分为:堆区.虚拟机栈.方法区.本地方法区和程序计数器,其中堆区是JVM中最大的一块内存区域,在Java中的所有对象实例都保存在此区域,它能被所有线程共享. 在 ...

  3. Git 几个常用操作

    git init        --    初始化仓库, git clone    --    从远端克隆仓库到本地 git status   --    查看git仓库的状态 git log    ...

  4. 经典问题----最小生成树(prim普里姆贪心算法)

    题目简述:假如有一个无向连通图,有n个顶点,有许多(带有权值即长度)边,让你用在其中选n-1条边把这n个顶点连起来,不漏掉任何一个点,然后这n-1条边的权值总和最小,就是最小生成树了,注意,不可绕成圈 ...

  5. c++ 创建线程以及参数传递

    //创建线程,传递参数 DWORD dwThreadID = ; HANDLE hThread = CreateThread(NULL, , MonitorThreadFunction, , & ...

  6. websocket 2 rest api

    需要开发一个prometheus 的exporter 使用jmespath 获取对应metrics的数据,并进行转换处理,但是因为那个服务 提供的接口是通过websoket 的实时api,所以基于no ...

  7. zabbix 监控进程

    参考资料 官方文档. 有时候某个进程挂了没有发现,直到业务中断才想起去检查.希望能有个功能在某个进程挂了以后发出告警. zabbix提供proc.num这个key对后台进程进行监控.原理很简单,其实就 ...

  8. 基于嵌入式linux路由转发功能的实现

    环境 arm7开发板, uclinux系统,kernel version: linux-2.4.x arm芯片的单网卡双网口设备,eth0 WAN口 ipaddr 192.168.9.61 eth0: ...

  9. 自动编译批处理设置(MSBuild)

    基本设置,如果想更改可以设置. @echo off rem --------------------------------- rem ----作成者:李暁賓--------------- rem - ...

  10. 树莓派中学TensorFlow

    树莓派中默认的虚拟环境为python 2.x,需要用下面的-p参数修改为python3环境.电信wifi和公司网络直接用pip3 install TensorFlow都不好使,用联通手机热点可以安装. ...