避免特征内存分配
Avoiding Eigen's Memory allocation
我想知道我是否可以自动从新内存中停止Eigen,以及这样做是否会加快速度。我附上了一个代码片段,这在某种程度上是我的程序的特点。
#define EIGEN_RUNTIME_NO_MALLOC
#include <Eigen/Dense>
using namespace std;
using namespace Eigen;
#define UNCONST(t,c,uc) Eigen::MatrixBase<t> &uc = const_cast<Eigen::MatrixBase<t>&>(c);
template <typename Derived>
void multiply (const MatrixBase<Derived> &A, MatrixBase<Derived> const &const_C){
Matrix<double, Dynamic, Dynamic>B;
B.setOnes(500,500);
UNCONST(Derived,const_C,C);
Eigen::internal::set_is_malloc_allowed(false);
C = A*B;
Eigen::internal::set_is_malloc_allowed(true);
}
int main(int argc, char** argv)
{
Matrix<double,Dynamic,Dynamic>A,C;
A.setOnes(500,500);
C.setOnes(500,500);
multiply(A,C);
}
我在调试模式下编译这段代码,当我执行它时,我会得到以下错误:
断言失败:(is_malloc_allowed()&"堆分配被禁止(定义了EIGEN_RUNTIME_NO_MALLOC并且g_is_MALLOC_allow为false)"),函数check_that_malloc_is_allowed,文件/3rdparty/Eigen/src/Core/util/Memory.h,第189行。
有没有办法关闭内存分配?
我很小心地确保作业左侧的矩阵具有正确的维度。我处理大矩阵,并重复使用类似multiply()
的函数。如果我停止这些malloc调用,代码中会有加速吗?
您可以使用noalias
:来避免产品的临时
C.noalias() = A * B;
如文件所示。
相关文章:
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?