我正在使用 Gnu Scientific Library (GSL),在那里我初始化了不同的向量。
现在我想将这些向量组合成一个向量,以便遍历整个向量。有谁知道一种方法,在哪里可以做到这一点?
这个问题以更一般的方式讨论了同样的问题,但我想知道是否有人知道直接使用 GSL 的方法(我将使用 GSL 中实现的排序功能)。
谢谢你,拉斯穆斯
如果您想坚持 GSL,但不单独设置所有矢量坐标,您可以使用gsl_vector_view
从gsl_vector_subvector
.
为此,分配足够大的输出 gsl_vector 以容纳所有不同向量的串联。然后对于这些使用中的每一个gsl_vector_subvector
来获得一个 gsl_vector_view 到输出向量的部分。然后,您可以gsl_vector_memcpy
从每个输入向量到相应的部分。请注意,gsl_vector_view 是一个结构,其中包含一个名为的 gsl_vector vector
:
#include <stdio.h>
#include <gsl/gsl_vector.h>
#define length1 4
#define length2 6
int main () {
/* allocate all vectors */
gsl_vector
*vectorIn1 = gsl_vector_alloc( length1 ),
*vectorIn2 = gsl_vector_alloc( length2 ),
*vectorOut = gsl_vector_alloc( length1+length2 );
/* fill input vectors with some test data */
for ( size_t index = 0; index < length1; ++index ) {
gsl_vector_set( vectorIn1, index, -(double)index );
}
for ( size_t index = 0; index < length2; ++index ) {
gsl_vector_set( vectorIn2, index, (double)index );
}
/* perform the copy to portions of the output */
{
gsl_vector_view
viewOut1 = gsl_vector_subvector( vectorOut, 0, length1 ),
viewOut2 = gsl_vector_subvector( vectorOut, length1, length2 );
gsl_vector_memcpy( &viewOut1.vector, vectorIn1 );
gsl_vector_memcpy( &viewOut2.vector, vectorIn2 );
}
/* display the result to see it is correct */
for ( size_t index = 0; index < length1 + length2; ++index ) {
printf( "%3.1f\n", gsl_vector_get( vectorOut, index ) );
}
/* be nice and tidy: release resources after use */
gsl_vector_free( vectorOut );
gsl_vector_free( vectorIn2 );
gsl_vector_free( vectorIn1 );
}
如果通过“初始化不同的向量”你的意思是初始化不同的 std::vectors,那么你的问题的答案是在这里使用 std::assign。
编辑1:在这种情况下, std::assign 是最好的答案(而不是许多地方建议的 std::copy )因为 std::copy 将一个接一个地插入新元素(而不是一次插入整个数组)并且可能导致多次重新分配(意思是:当您尝试将新元素插入到其当前大小(由 std::vector::size 给出)等于其当前容量(由 std::vector 给出: :capacity),重新分配使向量容量加倍。根据向量的大小,这可能会发生多次,这是一个非常(非常!)昂贵的操作。使用 std::assign 只会发生一次。
如果没有(意味着您有一个 gsl_vectors 的集合),那么原则上可以将 STL 算法与 C 数组一起使用, 请参见此处(gsl_vectors 包含一个名为 data 的 C 数组)。然而这是非常危险的,因为内存在 gsl_vectors 内的对齐方式很棘手。在这种情况下,您需要将它们手动转换为 std::vector 或手动合并为更大的 gsl_vector)
但是,除非您需要实现矩阵或需要使用向量进行非常快速的 BLAS 操作(请参见此处),否则我将始终使用 std::vector(并使用 std::vector::data 将 C 指针传递给 GSL 函数)。对于这两个例外,如果你想在 C++ 中工作,你应该使用Armadillo 线性代数包或Blaze(否则你需要编写一个包装器或类似 C 的代码)。