我在Eigen中编写了一个非常简单的函数,该函数应该创建线性独立的向量。相反,它始终创建nullvector。我希望解决方案非常简单,但是我看不到它。
为什么地球上向量mpbv的分量不都等于cos(0)= 1.00(在pi值的精度范围内)?
相反,我得到:
ludi@ludi-M17xR4:~/Desktop/tests$ g++ -O3 -w -o medrealbv.x medrealbv.cc -L/usr/local/lib -lgsl -lgslcblas && ./medrealbv.x
basisvector =
3.11621e-317
2.0776e-317
6.95251e-310
ludi@ludi-M17xR4:~/Desktop/tests$
因此,每个组件的值都非常接近零!我的程序如下。
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include <Eigen/Dense>
#define helix 3
#define pi 3.14159
using namespace Eigen;
typedef Matrix<double, helix, 1> VectorXh;
/*-- DECLARATIONS --*/
int basisvector(int m, VectorXh result);
/*--- MAIN ---*/
int main()
{
VectorXh mpbv;
basisvector(0, mpbv);
std::cout << "basisvector =\n" << mpbv << std::endl;
return(0);
}
/* --- --- */
int basisvector(int m, VectorXh result)
{
int k;
double component;
for(k=0;k<helix;k++)
{
component =cos(m*k*2.0*pi/helix);
result(k) = component;
}
return(0);
}
/* --- --- */
最佳答案
将函数签名更改为此:
int basisvector(int m, VectorXh & result) // note the ampersand
您正在做的是将
result
按值传递给函数。函数结束后,您在函数内部对result
参数所做的更改将丢失。关于c++ - 在EIGEN中错误设置 vector ,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/34227966/