特征:行大部分稀疏矩阵的不同行的内存预留
Eigen: different row-wise memory reservation for row major sparse matrix
在特征库中,是否有可能通过行保留空间为行稀疏矩阵行保留空间(每行都不同(?
我正在尝试优化填充非常大的稀疏矩阵的内存消耗(〜70mio x 70mio,〜2亿个NNZ是我能达到的最大的NNZ,但我想进一步走得更远(。澄清我走的方式:
首先,我使用的是推荐的setFromtreplet,这可能是填充矩阵的最快方法,但是检查内存消耗时,我在使用此功能的点上发现了峰值的平均内存的两倍,这是有意义的,因为我是我的 - 我 - 在某个时候 - 将Elments存储在两者,矩阵和三胞胎的向量中,直到向量脱离范围。
使用insert((显然改善了最大内存消耗。不过,由于重新分配,我仍然达到顶峰。然后,我还使用了Reserve((,因此没有(或更少(重新分配。它也大大降低了峰值,但是由于某些重新分配(如果Valgrind是正确的话(,它还没有完全消失。由于我的大多数行的NNZ都比最大值低,因此我在存储中获得了很多空的分配条目,从而增加了平均内存消耗。使用制定压缩会再次降低平均水平,但显然也使峰再次更高,因为在调用时必须进行更多的重新分配。
为什么我现在问上面的问题是:我可以在前一行计算NNZ,然后对它们进行排序,以便我实际上应该能够完全优化具有压缩矩阵而无需任何任何空分配,如果我可以为每一行保留不同数量的NNZ,则没有重新分配峰值。
如果有人会让我知道是否可能在特征中,我会很奇怪,如果没有:您知道任何支持它的库吗?
谢谢一堆!
是的,这是可能的,您可能已经在文档中找到了该功能:
template<class SizesType>
void SparseMatrix::reserve(const SizesType & reserveSizes);
请注意,SizesType
可以,例如std::vector
(或std::deque
(或Eigen::VectorXi
。
另外,如果您能够按顺序将元素插入矩阵,您也可以查看(内部(函数insertBack
。
- 将字符串存储在c++中的稳定内存中
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- Win32编译器选项和内存分配
- 当vector是tje全局变量时,c++中vector的内存管理
- 带内存和隔离功能的SQLite
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 迭代时从向量和内存中删除对象
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 为什么示例代码访问IUnknown中已删除的内存
- 如何在C++类内存结构中创建"spacer"?
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- 有没有一种方法可以测量c++程序的运行时内存使用情况
- 特征:行大部分稀疏矩阵的不同行的内存预留