我是PCL (点云库)的新手,我只想将ICP应用于两组点。然而,当我尝试在64位Visual Studio 2010中运行ICP的在线代码示例时,它抛出了一个致命错误。我尝试了创建点云的不同方法,但没有成功。在icp.setInputTarget内部的target_ = target.makeShared ();行发生致命错误
这就是我创建这两个云点的方法
pcl::PointCloud<pcl::PointXYZ>::Ptr cloud_in (new pcl::PointCloud<pcl::PointXYZ>);
cloud_in->width = _head_width+1;
cloud_in->height = _head_height+1;
cloud_in->is_dense = true;
for(int x=0; x<=width; x++) {
for(int y=0; y<=height; y++) {
float z = depths[x][y];
pcl::PointXYZ curr_point;
curr_point.x = x;
curr_point.y = y;
curr_point.z = z;
cloud_in->points.push_back(curr_point);
}
}这就是错误发生的地方
pcl::IterativeClosestPoint<pcl::PointXYZ, pcl::PointXYZ> icp;
icp_dummy.setInputCloud(cloud_in);
icp_dummy.setInputTarget(cloud_out); /* This throws a fatal error */任何帮助我们都将不胜感激。
发布于 2015-09-28 16:40:15
我有几个问题,在我看来是不正确的:-The地图不正确,x,y的值不是真实世界的坐标。
pcl::PointCloud<pcl::PointXYZ>::Ptr cloud (new pcl::PointCloud<pcl::PointXYZ>);
cloud->points.reserve(depthmap.rows*depthmap.cols);//for speeding up code, whitout it cost more time
cloud->is_dense = true;
//Don't know how it'd defined but try something like this by the depthmap
for(int x=0; x<depthmap.rows; x++) {
for(int y=0; y<depthmap.cols; y++) {
float z = depths[x][y];
pcl::PointXYZ curr_point;
curr_point.x = (x - cx) * z / fx; //for speedup calculate inverse of fx and multiply this
curr_point.y = (y - cy) * z / fy;//for speedup calculate inverse of fy and multiply this
curr_point.z = z;
cloud->points.push_back(curr_point);
}
}pcl::PointCloud<pcl::PointXYZ>::Ptr cloud_out;
pcl::IterativeClosestPoint<pcl::PointXYZ, pcl::PointXYZ> icp; //hereyou have to define icp
icp.setInputCloud(cloud_in);//so here icp_dummy needs to be icp
icp.setInputTarget(cloud_out); //so here icp_dummy needs to be icp
// The fatal error must be gone, otherwise change cloud_in to same type
// as cloud_outhttps://stackoverflow.com/questions/12046990
复制相似问题