- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我并不理解coo_matrix
、csr_matrix
和csc_matrix
之间的区别。
文档确实提到 coo_matrix 对于算术运算效率不高,我们需要将其转换为 csr
或 csc
。我正在研究矩阵乘法。如果我只有一个 coo_matrix
并将其转换为 csr
或 csv
矩阵,我不明白幕后发生了什么。
另外如果我有类似的东西
A = array([[1,2,3,0,0,5],
[5,0,0,1,2,0]])
print coo_matrix(A)
打印
(0, 0) 1
(0, 1) 2
(0, 2) 3
(0, 5) 5
这很酷。但是有没有办法,我可以直接输入我的矩阵作为打印的矩阵。类似于定义一个空 COO 矩阵,然后开始定义 coo_matrix
的值,就像我们在 matlab 中所做的那样。
谢谢!
最佳答案
这个术语不是 python scipy 发明的,而是已经存在于稀疏矩阵表示科学中
存在多种表示稀疏矩阵的格式。
格式可以分为两组:
坐标列表(COO)
COO stores a list of (row, column, value) tuples. Ideally, the entries are sorted (by row index, then column index) to improve random access times. This is another format which is good for incremental matrix construction
压缩稀疏行 (CSR)
压缩稀疏行 (CSR) 或压缩行存储 (CRS) 格式表示矩阵 M 由三个(一维)数组组成,分别包含非零值、行的范围和列索引。这种格式允许快速行访问和矩阵向量乘法。
CSR 格式使用三个(一维)数组(A、IA、JA)以行形式存储稀疏 m×n 矩阵 M。令NNZ表示M中非零项的个数。(注意这里应使用从零开始的索引。)
数组 A 的长度为 NNZ,并以从左到右从上到下(“行优先”)的顺序保存 M 的所有非零条目。
因此,IA的前m个元素存储了M中每行第一个非零元素到A中的索引,最后一个元素IA[m]存储了NNZ,即A中的元素个数,也可以认为of 作为矩阵 M 末尾之后的幻像行的第一个元素在 A 中的索引。
从元素 A[IA[i]] 中读取原始矩阵的第 i 行的值到 A[IA[i + 1] − 1](包括两端),即从一行的开始到下一行开始之前的最后一个索引。
第三个数组 JA 包含 A 的每个元素在 M 中的列索引,因此长度也是 NNZ。
For example, the matrix 0 0 0 0
5 8 0 0
0 0 3 0
0 6 0 0
是一个有 4 个非零元素的 4 × 4 矩阵,因此
A = [ 5 8 3 6 ]
IA = [ 0 0 2 3 4 ]
JA = [ 0 1 2 1 ]
关于python - scipy:基本说明,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11216906/
我正在查看预先重写的 jQuery 代码。我无法理解以下代码。 $('body > *:not(#print-modal):not(script)').clone(); 最佳答案 此选择器匹配以下任何
所以我开始学习MySQL,我对表有点困惑,所以我想澄清一下。数据库中可以有多个表吗?例如: Database1 -Table1 -Username -Password -Table2 -Name
我在 PostgreSQL 中编写了一个函数,其代码如下: for (i = 0; i str[0][i]); values[i] = datumCopy(dat_value,
oid: 行的对象标识符(对象 ID)。这个字段只有在创建表的时候使用了 WITH OIDS ,或者是设置了default_with_oids 配置参数时出现。 这个字段的类型是 oid (和字段同
我在搜索最大连接设备数时发现了 a post大致说: 当使用 P2P_STAR 时,最大设备数量为 10,因为此 topoly 使用 Wi-Fi 热点。也就是说,如果您没有路由器。 这让我问了两个问题
我不明白为什么会这样: Printf.sprintf "%08s" "s" = Printf.sprintf "%8s" "s" - : bool = true 换句话说,我希望: Printf.sp
我正在遵循 Grails in Action 中的示例。我有一个问题,如何理解 addTo*()功能有效。 我有一个简单的域:具有以下关系的用户、帖子、标签: 用户1对M发帖 用户一对一标签 发布 M
请问为什么行 "b[0]= new Child2();"在运行时而不是在编译时失败。请不要检查语法,我只是在这里做了 class Base {} class Child1 : Base {} clas
所以我想进一步加深我对套接字的理解,但是我想首先从最低级别开始(在C语言中,而不是在汇编中大声笑) 但是,我处理的大多数站点都使用SOCK_STREAM或SOCK_DGRAM。但是我已经阅读了Beej
好吧,我对 javascript 语法了解甚少,而且我对 null 的行为感到非常困惑。关于空值有很多讨论,但我似乎无法找出问题所在!请帮我。这是脚本。 var jsonData = '';
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭5 年前。 Improve thi
问题: SeriesSum 类旨在计算以下系列的总和: 类名:SeriesSum 数据成员/实例变量: x:存储整数 n:存储术语数量 sum:用于存储系列总和的双变量 成员函数: SeriesSum
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
今天我在 logcat 中注意到以下内容: D/OpenGLRenderer:0xa2c70600 (CardView) 上的 endAllStagingAnimators,句柄为 0xa2c9d35
如何创建值有序对的列表,例如list1 [(x, y), (x1, y1) ...].?? 学习如何创建此列表后,我需要知道如何将 x 值提供给列表中的用户输入并搜索 x 的下一个值并显示有序对 (x
我在存储过程中有以下逻辑。 这里完成了什么? 如果color为null,替换为'' IF ISNULL(@color, '') <> '' BEGIN END 最佳答案 它等同于: IF (@colo
我知道.Net中的接口(interface)定义了接口(interface)和继承它的类之间的契约。刚刚完成了一个大量使用数据访问层接口(interface)的项目,这让我开始思考。 . .有什么大不
如何防止基类方法被子类覆盖 最佳答案 您不需要做任何特别的事情:默认情况下方法是不可覆盖的。相反,如果您希望该方法可重写,则必须将 virtual 关键字添加到其声明中。 但是请注意,即使方法不可重写
我已阅读以下有关工厂模式的文章 here 请仅引用Class Registration - avoiding reflection这一部分。 这个版本在没有反射的情况下实现了工厂和具体产品之间的减少耦
我正在学习 Java 类(class),但无法完全理解下一课的内容。 目的:本课的目的是通过创建一个模拟 for-each 循环如何工作的替代方案来解释 for-each 循环的工作方式。 在上一课中
我是一名优秀的程序员,十分优秀!