我也在寻找同样的功能,但是没有找到,于是我自己实现了它。这里是C++代码。
首先,你需要使用焦距和中心点来归一化图像点。
rpt(0) = (pt_x - cx) / fx
rpt(1) = (pt_y - cy) / fy
接着扭曲规范化图像点。
double x = rpt(0), y = rpt(1);
//determining the radial distortion
double r2 = x*x + y*y;
double icdist = 1 / (1 - ((D.at<double>(4) * r2 + D.at<double>(1))*r2 + D.at<double>(0))*r2);
//determining the tangential distortion
double deltaX = 2 * D.at<double>(2) * x*y + D.at<double>(3) * (r2 + 2 * x*x);
double deltaY = D.at<double>(2) * (r2 + 2 * y*y) + 2 * D.at<double>(3) * x*y;
x = (x + deltaX)*icdist;
y = (y + deltaY)*icdist;
接下来,您可以使用投影中心和焦距对该点进行翻译和缩放:
x = x * fx + cx
y = y * fy + cy