目前,我正在以这种方式将4x4垫和Point3f相乘,
有没有更有效的方法来进行这种乘法?
注意:我还需要将结果转换回cv :: Point3f
由于
cv::Mat cam_to_world(4, 4, CV_32FC1);
///....
cv::Mat pointA_cam(4, 1, CV_32FC1);
pointA_cam.at<float>(0, 0) = OAvec_cam.x;
pointA_cam.at<float>(1, 0) = OAvec_cam.y;
pointA_cam.at<float>(2, 0) = OAvec_cam.z;
pointA_cam.at<float>(3, 0) = 1.0;
cv::Point3f point_A_wld;
cv::Mat point_A_world = cam_to_world*pointA_cam;
point_A_wld.x = point_A_world.at<float>(0, 0);
point_A_wld.y = point_A_world.at<float>(1, 0);
point_A_wld.z = point_A_world.at<float>(2, 0);
答案 0 :(得分:1)
这就是我所拥有的,如果有人有更紧凑的解决方案,它会有所帮助
cv::Mat cam_to_world(4, 4, CV_32FC1);
cv::Mat pointA_cam = cam_to_world*Mat(cv::Vec4f(OAvec_cam.x,OAvec_cam.y,OAvec_cam.z,1.0));
cv::Point3f point_A_wld(cam_to_world.at<float>(0,0),cam_to_world.at<float>(1,0),cam_to_world.at<float>(2,0));