如何用openCV实现VP中的CogCalibCheckerboardTool校正工具功能

6 篇文章 11 订阅

    前面文章大概介绍了VP的CogCalibCheckerboardTool工具主要是来校正相机畸变的,VP平台好用是好用不过需要加密狗才能使用,而加密狗的价格也非常的昂贵,如果用开源免费平台来实现VP中的功能可以节省很大一笔费用,所以下面来介绍下如何用开源平台来实现VP中的一些工具的功能,这一篇文章先介绍下如何用openCV实现VP中的CogCalibCheckerboardTool校正工具功能:

//定义传入棋盘格图片变量
cv::Mat imtepImg = image.clone();

//定义角点集合变量
vector<cv::Point2f> corners;

//定义一个30行30列角点
cv::Size board_size = cv::Size(30, 30);

//findChessboardCorners函数找到角点坐标
bool patter = cv::findChessboardCorners(image, board_size, corners, CV_CALIB_CB_ADAPTIVE_THRESH | CV_CALIB_CB_NORMALIZE_IMAGE);

//如果未找到角点终止返回
if (!patter)
{
    return;
}

//对像素坐标进行亚精度操作,提高精度
cv::cornerSubPix(image, corners, cv::Size(11, 11), cv::Size(-1, -1), cv::TermCriteria(CV_TERMCRIT_EPS + CV_TERMCRIT_ITER, 30, 0.1));

//在棋盘格上找到的所有角点画半径为3的小圈圈
for (int i = 0; i < corners.size(); i++)
{
	cv::circle(imtepImg, corners[i], 3, cv::Scalar(255, 0, 0), 2);
}

// 把找到的角点描绘出来
cv::drawChessboardCorners(colorImg, board_size, corners, patter);

//单个棋盘格大小 mm
cv::Size square_size = cv::Size(5, 5);

//创建 3*3 全零的 float 矩阵,用来保存相机内参
cv::Mat cameraMatrix = cv::Mat(3, 3, CV_32FC1, cv::Scalar::all(0));

//创建 1行5列的全零 float 矩阵,用来保存畸变参数
cv::Mat distcoeffs = cv::Mat(1, 5, CV_32FC1, cv::Scalar::all(0));

// 创建图像旋转向量
vector<cv::Mat> tvecsMat;

//创建图像平移向量
vector<cv::Mat> rvecsMat;

//保存各角点的物理坐标	 世界坐标系
vector<cv::Point3f> realPoints;

//按照从左到右,从上到下的顺序排列角点坐标 每个角点的坐标是以棋盘格真实大小转换
for (int i = 0; i < board_size.height; i++)
{
	for (int j = 0; j < board_size.width; j++)
	{
		cv::Point3f tempPoint;
		tempPoint.x = i*square_size.width;
		tempPoint.y = j*square_size.height;
		tempPoint.z = 0;
		realPoints.push_back(tempPoint);
	}
}

// 可以存放多个棋盘格画面
vector<vector<cv::Point2f>> image_points;
image_points.push_back(corners);
// 对应的棋盘格真实大小角点坐标集合
vector<std::vector<cv::Point3f>> object_points;
object_points.push_back(realPoints);

//calibrateCamera函数计算相机畸变内参 外参等
double eps = cv::calibrateCamera(object_points, image_points, image.size(), cameraMatrix, distcoeffs, rvecsMat,
		tvecsMat, CV_CALIB_FIX_K3);
double err = 0.0;

//定义畸变校正后的输出图像
cv::Mat dstImage;

//调用相机畸变内外参 得到校正后的图像
cv::undistort(image, dstImage, cameraMatrix, distcoeffs);

//定义校正后的角点坐标集
vector<cv::Point2f> corner;

//在校正后的图片中找到所有的角点坐标
bool patters = cv::findChessboardCorners(dstImage, board_size, corner, CV_CALIB_CB_ADAPTIVE_THRESH | CV_CALIB_CB_NORMALIZE_IMAGE);

//保存相机校正内外参数据
ofstream fout;
fout.open("参数文档.txt");
fout << "#cameraMatrix:\n" << cameraMatrix << endl;
fout << "#distcoeffs:\n" << distcoeffs << endl;
fout << endl;
fout.close();

dstImage就是我们想要的校正后的图片;corner 就是校正后的角点坐标 ;cameraMatrix  和 distcoeffs 就是相机的内外参数;

相机畸变校正就介绍到这,接下来 下一篇文章介绍OpenCV如何利用N(N=4)点转换为机器人或其他设备坐标系

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
畸变校正是图像处理的一个重要步骤,它可以消除图像因镜头畸变而引起的失真现象。OpenCV是一个广泛使用的计算机视觉库,它提供了许多图像处理的函数和工具。下面是一个使用OpenCV 4.7版本实现畸变校正的示例代码。 首先,我们需要读取原始图像和相机的畸变参数。假设我们已经有了一个名为"image.jpg"的图像和一个名为“camera.xml”的相机参数文件。可以使用以下代码加载它们: ``` python import cv2 # Load image img = cv2.imread("image.jpg") # Load camera parameters with open("camera.xml", 'r') as f: parameters = f.read() ``` 注意,相机参数文件应该是XML格式的,并且应该包含以下参数: - camera_matrix: 相机内部参数矩阵 - dist_coeffs: 相机畸变系数 接下来,我们需要使用相机参数和图像的大小创建一个畸变校正映射。这可以通过cv2.initUndistortRectifyMap函数完成。示例代码如下: ``` python # Get image size h, w = img.shape[:2] # Load camera parameters with open("camera.xml", 'r') as f: parameters = f.read() # Parse camera parameters camera_params = cv2.omnidir_undistorter.parseXML(parameters) # Create rectification map map1, map2 = cv2.omnidir_undistorter.initUndistortRectifyMap( camera_params["camera_matrix"], camera_params["dist_coeffs"], camera_params["xi"], np.eye(3), camera_params["new_size"], cv2.CV_16SC2) ``` 在上面的代码,我们首先获取图像的大小。然后,我们解析相机参数,并使用cv2.omnidir_undistorter.initUndistortRectifyMap函数创建了一个校正映射。这个函数需要以下参数: - camera_matrix: 相机内部参数矩阵 - dist_coeffs: 相机畸变系数 - xi: xi参数,用于描述广角镜头的畸变 - R: 旋转矩阵,用于对图像进行旋转 - new_size: 输出图像的大小 - map1, map2: 输出的校正映射 一旦我们有了校正映射,我们就可以使用cv2.remap函数来对图像进行畸变校正。示例代码如下: ``` python # Apply rectification map undistorted = cv2.remap(img, map1, map2, cv2.INTER_LINEAR) ``` 在上面的代码,我们使用cv2.remap函数将校正映射应用于原始图像。这个函数需要以下参数: - src: 输入图像 - map1, map2: 校正映射 - interpolation: 插值方法 最后,我们可以将校正后的图像保存到文件。示例代码如下: ``` python # Save output image cv2.imwrite("undistorted.jpg", undistorted) ``` 以上就是使用OpenCV 4.7版本实现畸变校正的完整代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

会飞的黑鸭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值