4个版本 (2个重大变更)
0.3.0 | 2022年6月20日 |
---|---|
0.2.0 | 2021年3月18日 |
0.1.1 | 2020年10月1日 |
0.1.0 | 2020年9月29日 |
#1764 in 算法
每月23次下载
用于 sprs-ldl
485KB
12K SLoC
sprs, 为Rust提供稀疏矩阵
sprs在纯Rust中实现了某些稀疏矩阵数据结构和线性代数算法。
API仍在开发中,对其粗糙边缘的反馈非常欢迎 :)
特性
结构
- CSR/CSC矩阵
- 三元组矩阵
- 稀疏向量
运算
- 稀疏矩阵/稀疏向量乘积
- 稀疏矩阵/稀疏矩阵乘积
- 稀疏矩阵/稀疏矩阵加法、减法
- 稀疏向量/稀疏向量加法、减法、点积
- 稀疏/密集矩阵运算
算法
- 压缩稀疏矩阵的外迭代器
- 稀疏向量迭代
- 稀疏向量联合非零迭代
- 简单的稀疏Cholesky分解(需要选择LGPL许可)
- 具有密集右端项的稀疏三角求解
示例
矩阵构造
use sprs::{CsMat, CsMatOwned, CsVec};
let eye : CsMatOwned<f64> = CsMat::eye(3);
let a = CsMat::new_csc((3, 3),
vec![0, 2, 4, 5],
vec![0, 1, 0, 2, 2],
vec![1., 2., 3., 4., 5.]);
矩阵向量乘法
use sprs::{CsMat, CsVec};
let eye = CsMat::eye(5);
let x = CsVec::new(5, vec![0, 2, 4], vec![1., 2., 3.]);
let y = &eye * &x;
assert_eq!(x, y);
矩阵矩阵乘法,加法
use sprs::{CsMat, CsVec};
let eye = CsMat::eye(3);
let a = CsMat::new_csc((3, 3),
vec![0, 2, 4, 5],
vec![0, 1, 0, 2, 2],
vec![1., 2., 3., 4., 5.]);
let b = &eye * &a;
assert_eq!(a, b.to_csr());
要查看更完整的示例,请务必查看热扩散示例。
文档
文档可在docs.rs找到。
变更日志
查看变更日志。
支持的Rust最低版本
当前支持的Rust最低版本为1.64。在1.0版本之前,提高MSRV不会被视为破坏性更改,但将尽最大努力避免破坏。
许可证
根据您选择以下任一项许可证授权:
- Apache License, Version 2.0, (LICENSE-APACHE 或 https://apache.ac.cn/licenses/LICENSE-2.0)
- MIT许可证 (LICENSE-MIT 或 https://opensource.org/licenses/MIT)
任选其一。
贡献
除非您明确声明,否则根据Apache-2.0许可中定义的,您有意提交以包含在作品中的任何贡献,应双重许可,如上所述,无需任何附加条款或条件。
请参阅贡献指南以获取有关贡献的更多信息。
依赖项
~2MB
~40K SLoC