3D点云之单目标定

一、在进行单目标定之前,需要进行以下工作

1、用被标定的相机拍照,拍15-20张棋盘格的照片,棋盘格尽量覆盖到图片的上下左右中间,

2、将上述所拍的图片放到同个文件夹里面,并按一定规则命名。

3、创建一个.txt 的文件里面的内容是上述图片的位置。

 二、单目标定(基于opencv库)

单目标定的主要步骤为

1、通过findChessboardCorners找到棋盘上的所有角点,
2、然后再通过调用cornerSubPix(image只能单通道)亚像素精确化,找到精确的角点坐标,
3、然后调用drawChessboardCorner画出角点位置。
4、stereoCalibrate 单目标定

#include "stdafx.h"
#include "SemiGlobalMatching.h"
#include <chrono>
#include <fstream>
#include <vector>

using namespace std::chrono;

// opencv library
#include <opencv2/opencv.hpp>
#ifdef _DEBUG
#pragma comment(lib,"opencv_world310d.lib")
#else
#pragma comment(lib,"opencv_world310.lib")
#endif


/*                  单目标定
*    std::ifstream fin("../05right720p/right.txt");              标定所用图像文件的路径,注意文件名可能有空格 
* std::ofstream fout("../caliberation_result_right.txt");        保存标定结果的文件 
* 只有以上两个地方需要修改
* 一个是被标定的图片保存的位置(每个都要罗列在right.txt里面,比如: C:\Users\13716\Desktop\projecting\code\semiglobalmatching-master\05right720p\1.jpeg)
* caliberation_result_right.txt是保存结果的文件
*/
 /*通过findChessboardCorners找到棋盘上的所有角点,
  *然后再通过调用cornerSubPix(image只能单通道)亚像素精确化,找到精确的角点坐标,
  *然后调用drawChessboardCorner画出角点位置。
  *calibrateCamera 开始标定
  * stereoCalibrate
  */

#define calibration

int main(int argv, char* argc[])
{
#ifdef calibration
    std::ifstream fin("../05right720p/right.txt"); /* 标定所用图像文件的路径,注意文件名可能有空格 */
    std::ofstream fout("../caliberation_result_right.txt");  /* 保存标定结果的文件 */
    // 读取每一幅图像,从中提取出角点,然后对角点进行亚像素精确化
    int image_count = 0;  /* 图像数量 */
    cv::Size image_size;      /* 图像的尺寸 */
    cv::Size board_size = cv::Size(11, 8);             /* 标定板上每行、列的角点数 */
    std::vector<cv::Point2f> image_points_buf;         /* 缓存每幅图像上检测到的角点 */
    std::vector<std::vector<cv::Point2f>> image_points_seq; /* 保存检测到的所有角点 */
    std::string filename;      // 图片名
    std::vector<std::str
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

红萝白

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

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

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

打赏作者

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

抵扣说明:

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

余额充值