当前位置: 首页 > news >正文

【机器视觉------标定篇(二)】三点成圆算法(求相机旋转中心)

应用场景

机器视觉项目应用中,相机安装在机器人上,并且需要定位产品返回坐标偏差以及角度偏差。
与九点标定配合使用,实现精准角度补偿。

算法输入

不共线的三点坐标 A(X₁,Y₁) ,B(X₂,Y₂) ,C(X₃,Y₃)
在这里插入图片描述

算法原理及实现

原理:

由图可知,线OA=OB=OC=外接圆的半径(r),从三点向【以O点为原点的坐标系】做垂线。由勾股定理可得:

(X - X₀)² + (Y - Y₀)² = r ²

由上式带入三点坐标可的可得:
在这里插入图片描述
公式变换可得(由公式①-②,①-③):
计算圆心公式
由于上公式可得,该式有唯一解的条件为:
在这里插入图片描述
即任两点组成的斜率不能相等,也验证了三点成圆条件:三点不共线。

实现:

设:
a = 2(X₁ - X₂)
b = 2(Y₁ - Y₂)

c = 2(X₁ - X₃)
d= 2(Y₁ - Y₃)

e = (X₁)² - (X₂)² + (Y₁)² - (Y₂)²
f = (X₁)² - (X₃)² + (Y₃)² - (Y₃)²

代回方程:
在这里插入图片描述

代码实现

 public PointF CalculateCicular(PointF px1, PointF px2, PointF px3)
{float x1, y1, x2, y2, x3, y3;float a, b, c, g, e, f, X, Y;x1 = px1.X;y1 = px1.Y;x2 = px2.X;y2 = px2.Y;x3 = px3.X;y3 = px3.Y;a = 2 * (x1 - x2);b = 2 * (y1 - y2);c = 2 * (x1 - x3);d = 2 * (y1 - y3);e = x1 * x1 - x2 * x2 + y1 * y1 - y2 * y2;f = x1 * x1 - x3 * x3 + y1 * y1 - y3 * y3;X = (e * d - b * f) / (a * d - b * c);  Y = (e * c - a * f) / (b * c - a * d);//R = (float)Math.Sqrt((X - x1) * (X - x1) + (Y - y1) * (Y - y1)); //半径PointF center = new PointF(X, Y);return center;
}
http://www.lryc.cn/news/59473.html

相关文章:

  • AUTOSAR E2E详细介绍
  • Dream 主题使用手册 - 基础篇
  • WSL下的Kafka开发容器:Docker搭建、API、整合
  • cv2(OpenCV)下载安装
  • 【剑指 offer】旋转数组的最小数字
  • GB 9706.1-2020 医用电气设备第1部分:基本安全和基本性能的通用要求-1
  • 认识C++《共、枚、指1》
  • vim 一键配置
  • 如何成为一名成功的 PHP 开发者
  • UHD安装教程
  • Unity和UE有啥区别?哪个更适合游戏开发
  • 红队内网靶场
  • 如何合并多个升序链表?
  • 23上半年信息系统项目管理师新老教程兼顾使用备考策略
  • Linux环境搭建SVN服务器并实现公网访问 - cpolar端口映射
  • 仿牛客网社区Web开发项目代码逐行精读(更新中)
  • 5G NR调制阶数与EVM关系以及对系统SNR要求分析
  • 【NAS群晖drive异地访问】远程连接drive挂载电脑硬盘「内网穿透」
  • react:hooks为什么不能写在条件语句里
  • 模型优势缺陷整理
  • 编写猫咪相册应用 HTML
  • 基于Arduino与LabVIEW的远程家庭监控系统
  • 使用FRP(快速反向代理)实现内网穿透——以腾讯云服务器为例
  • d跨语言链接优化
  • 【Linux】-- 进程概念的引入
  • 一文看懂“低代码、零代码”是什么?有什么区别?
  • 【华为OD机试真题】去除多余的空格(java)
  • 【SQL 必知必会】- 第十三课 创建高级联结
  • ios逆向工具有那些
  • 【软件设计师14】UML建模