在C ++中将向量设置为矩阵算法帮助

时间:2011-12-29 04:17:48

标签: c++ gsl

我有一个具有M * N个元素的数组X,我正在尝试使用相同的数据创建一个大小为M x N的矩阵A.我正在使用gsl作为矩阵,X被声明为数组。我遇到了麻烦,我不断在矩阵中重叠。

这是我想要做的一个例子:

Vector X[4*2]
1,2,3,4,5,6,7,8

Matrix A 4X2
1, 2 
3, 4
5, 6
7, 8

//heres one of my many fail attempts as an example
//creation of array X here
X[n*m] = someCbasedformulafromtheweb(n, m);
//gsl matrix allocation for matrix A N x M
gsl_matrix * A = gsl_matrix_alloc(n, m);
for(int i=0; i<n; i++) { 
    for(int j=0; j<m; j++) { 
        // setting the x[i*j] entry to gsl_matrix A at positions i , j
        gsl_matrix_set (A,i,j, x[i*j]);
    }
}

2 个答案:

答案 0 :(得分:2)

我没有gsl可以玩,但这不会起作用吗?

for (i=0 ; i<4 ; ++i)
  for (j=0 ; j<2 ; ++j)
    X[2*i + j] = gsl_matrix_get (&A, i, j));

答案 1 :(得分:1)

你的问题就在这一行:

gsl_matrix_set (A,i,j, x[i*j]);

以下是表格:

i | j | x[i*j]
0 | 0 | x[0]
0 | 1 | x[0]
1 | 0 | x[0]
1 | 1 | x[1]
2 | 0 | x[0]
2 | 1 | x[2]
3 | 0 | x[0]
3 | 1 | x[3]

相反,您需要使用:

gsl_matrix_set (A,i,j, x[2*i+j]);

i | j | x[2*i+j]
0 | 0 | x[0]
0 | 1 | x[1]
1 | 0 | x[2]
1 | 1 | x[3]
2 | 0 | x[4]
2 | 1 | x[5]
3 | 0 | x[6]
3 | 1 | x[7]