我在连接两个向量时遇到了一些问题。
std::vector<Transform3D> out;
for(double theta = 0; theta <= 2*M_PI ; theta+=1 )
{
for(double phi = 0; phi <= M_PI ; phi+=1 )
{
double sphere_x = obj_x + r*cos(theta)*sin(phi);
double sphere_y = obj_y + r*sin(theta)*sin(phi);
double sphere_z = obj_z + + r*cos(phi);
Transform3D<> transformation_matrix = transform(obj_x,obj_y,obj_z,sphere_x,sphere_y,sphere_z);
if(0.01<(transformation_matrix.P()[0] - current_x) ||
0.01<transformation_matrix.P()[1] - current_y ||
0.01<transformation_matrix.P()[2] - current_z)
{
cout << "Interpolate: " << endl;
std::vector<Transform3D> transformation_i = invKin_LargeDisplacement(transformation_matrix);
out.insert(out.end(),transformation_i.begin(),transformation_i.end());
}
else
{
cout << "OK" << endl;
out.push_back(transformation_matrix);
}
cout << out.size() << endl;
cout << sizeof(Transform3D<>) << endl;
}
}
out.insert(..)
似乎导致了
bad_alloc
,但需要额外的数据。
在调试问题时,我在运行for循环时打印了矢量的大小,并得到了以下输出:
Interpolate:
6346700
Interpolate:
12052200
Interpolate:
16476100
Interpolate:
20127501
Interpolate:
26474201
Interpolate:
32239601
Interpolate:
36748301
Interpolate:
40416502
Interpolate:
46763202
Interpolate:
52659402
Interpolate:
57349102
Interpolate:
61053903
Interpolate:
67400603
Interpolate:
73377503
Interpolate:
terminate called after throwing an instance of 'std::bad_alloc'
what(): std::bad_alloc
Aborted (core dumped)
有什么办法可以避免
错误分配(_A)
,同时仍然能够插值?