OpenCv 九点标定不准确的问题

2024-01-08 08:20

本文主要是介绍OpenCv 九点标定不准确的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1,物理条件

如图所示,X Y 为分离轴,相机固定在X轴上,载台固定在Y轴上,产品放在载台上,产品对角上有mark点,用相机识别mark点,获取mark点的像素坐标和轴的xy坐标,数据如下:

std::vector<cv::Point2f> camera;std::vector<cv::Point2f> robot;camera.push_back(cv::Point2f(153.5 , 781.5));camera.push_back(cv::Point2f(580.5 , 783.5));camera.push_back(cv::Point2f(1006.5 , 784.5));camera.push_back(cv::Point2f(153.5 , 436.5));camera.push_back(cv::Point2f(581.5 , 435.5 ));camera.push_back(cv::Point2f(1008.5 , 438.5));camera.push_back(cv::Point2f(154.5 , 90.5));camera.push_back(cv::Point2f(581.5 , 89.5));camera.push_back(cv::Point2f(1008.5 , 91.5));robot.push_back(cv::Point2f(552348 , 541607));robot.push_back(cv::Point2f(555548 , 541607));robot.push_back(cv::Point2f(558748 , 541607));robot.push_back(cv::Point2f(552348 , 544207));robot.push_back(cv::Point2f(555548 , 544207));robot.push_back(cv::Point2f(558748 , 544207));robot.push_back(cv::Point2f( 552348 , 546807));robot.push_back(cv::Point2f( 555548 , 546807 ));robot.push_back(cv::Point2f(558748 , 546807));

 用Opencv放射变换计算出两个坐标对应的矩阵关系M

cv::Mat matrix = cv::estimateAffinePartial2D(camera,robot);A = matrix.ptr<double>(0)[0];B = matrix.ptr<double>(0)[1];C = matrix.ptr<double>(0)[2];D = matrix.ptr<double>(1)[0];E = matrix.ptr<double>(1)[1];F = matrix.ptr<double>(1)[2];

那么连个坐标系之间的映射关系如下:


QPair<float, float> MainWindow::getRobotPosition(float x, float y)
{QPair<float,float> pair;pair.first = (A*x) + B* y + C;pair.second = (D*x) + E* y + F;return pair;
}

为了验证M是否正确,我们常用的做法是将camera集合里面的坐标带入到公式中 计算出机械坐标,然后跟实际的机械坐标相减,看看差值的范围

    qDebug()<<"["<<getRobotPosition(153.5 , 781.5).first - robot.at(0).x<< "  , "<<getRobotPosition(153.5 , 781.5).second - robot.at(0).y<<"]";qDebug()<<"["<<getRobotPosition(580.5 , 783.5).first - robot.at(1).x<< "  , "<<getRobotPosition(580.5 , 783.5).second - robot.at(1).y<<"]";;qDebug()<<"["<<getRobotPosition(1006.5 , 784.5).first - robot.at(2).x<< " , "<<getRobotPosition(1006.5 , 784.5).second - robot.at(2).y<<"]";;qDebug()<<"["<<getRobotPosition(153.5 , 436.5).first - robot.at(3).x<< " , "<<getRobotPosition(153.5 , 436.5).second - robot.at(3).y<<"]";;qDebug()<<"["<<getRobotPosition(581.5 , 435.5 ).first - robot.at(4).x<< "  , "<<getRobotPosition(581.5 , 435.5 ).second - robot.at(4).y<<"]";;qDebug()<<"["<<getRobotPosition(1008.5 , 438.5).first - robot.at(5).x<< "  , "<<getRobotPosition(1008.5 , 438.5).second - robot.at(5).y<<"]";;qDebug()<<"["<<getRobotPosition(154.5 , 90.5).first - robot.at(6).x<< " , "<<getRobotPosition(154.5 , 90.5).second - robot.at(6).y<<"]";;qDebug()<<"["<<getRobotPosition(581.5 , 89.5).first - robot.at(7).x<< " , "<<getRobotPosition(581.5 , 89.5).second - robot.at(7).y<<"]";;qDebug()<<"["<<getRobotPosition(1008.5 , 91.5).first - robot.at(8).x<< " , "<<getRobotPosition(1008.5 , 91.5).second - robot.at(8).y<<"]";;

到这地方发现,偏差极其的大,大到完全无法接受

[ 5075.56   ,  6283.69 ]
[ 2555.38   ,  3149.38 ]
[ 26.25  ,  20.9375 ]
[ 2540.69  ,  3146.31 ]
[ 0   ,  0 ]
[ -2512.88   ,  -3132.69 ]
[ 0  ,  0 ]
[ -2542.25  ,  -3138.94 ]
[ -5062.44  ,  -6273.19 ]

到这里我一直怀疑是不是 获取Mark点中心坐标的时候计算错了?但仔细检查了后发现没有,于是想到用Halcon验证一下:

 发现算出的矩阵M和Opencv算出来的完全不一样,带入M  计算差值:

[ 1.625   ,  5.0625 ]
[ 1.625   ,  -2.4375 ]
[ -5.875  ,  -2.4375 ]
[ -3.375  ,  -4.9375 ]
[ 4.125   ,  10.0625 ]
[ 4.125   ,  -4.9375 ]
[ -0.875  ,  -7.5 ]
[ -0.875  ,  7.5625 ]
[ -0.875  ,  0 ]

最大偏差在10个脉冲之类(我一个脉冲 1um)完全可以接受。

不知道这是为什么

这篇关于OpenCv 九点标定不准确的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/582850

相关文章

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map