仍在学习 C++ 的基本知识。
我正在将一个 CSV 文件导入一个 vector < vector >,将其更改为一个数组数组,然后创建一个 Mat(一种 openCV 数据类型)用于在 SVM 中进行训练。
我可以正确构建 vector ,但在将 vector 转换为数组时遇到问题,并且出现此错误: 无法在赋值中将“std::vector”转换为“double”
由于某些原因,第一个复制语句给出了这个错误,而循环中的复制语句工作正常。
vector< vector<double> > labelsVec;
vector< vector<double> > trainingDataVec;
read_csv(infile1, labelsVec);
read_csv(infile2, trainingDataVec);
double labels[178] = {0.0};
double trainingData[178][5] = {0.0};
copy(labelsVec.begin(), labelsVec.end(), labels);
for (int row = 0; row < trainingDataVec.size(); ++row) {
copy(trainingDataVec[row].begin(), trainingDataVec[row].end(), trainingData[row]);
}
Mat labelsMat(178, 1, CV_32SC1, labels);
Mat trainDataMat(178, 5, CV_32FC1, trainingData);
最佳答案
您不需要复制 vector<double>
到 double*
除非在非常特殊的情况下。该标准保证 vector 元素存储在连续内存中,因此您基本上可以使用 vector<T>
的第一个元素的地址。作为 T*
的数组. C++11 已经通过 data()
为您提供了此功能方法。
我从未使用过 OpenCV,所以我不知道它是否需要整个数据矩阵是连续的,所以我不确定这个解决方案是否适用于您的问题。
这当然不能直接应用于二维数据,但您可以轻松地使用一个变通方法,即只为第一维填充一个数组,请查看 this code :
#include <iostream>
#include <vector>
using namespace std;
void foo(double** data, size_t i, size_t j)
{
for (size_t ii = 0; ii < i; ++ii)
for (size_t jj = 0; jj < j; ++jj)
cout << data[ii][jj] << endl;
}
int main(void) {
vector<vector<double>> data = {{0.0f, 1.0f}, {2.0f, 3.0f}};
const size_t rows = data.size();
const size_t cols = data[0].size();
double** arrayData = new double*[rows];
for (size_t i = 0; i < rows; ++i)
arrayData[i] = &data[i][0];
// ^ this obtains the address of first element of i-th row,
// where the vector data begins
// you can use arrayData[i] = data[i].data() if you have C++11 support
foo(arrayData, rows, cols);
delete [] arrayData;
return 0;
}
我为其使用动态分配只是因为硬编码大小可能是也可能不是一个好主意(取决于优化要求等)。
关于c++ - vector会不会copy成数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33113916/