news 2026/5/30 15:18:09

VisionPro二开之九点标定

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
VisionPro二开之九点标定

VisionPro二开之九点标定

方式1:

CogCalibNPointToNPointTool

方式2

安装

平移九点标定

usingSystem;usingSystem.Collections.Generic;usingMathNet.Numerics.LinearAlgebra;namespace平移标定的数学公式{publicclassCoordinateCalibration{// 存储标定点对privateList<(PointF image,PointF robot)>calibrationPoints=newList<(PointF,PointF)>();// 仿射变换参数 [a, b, c; d, e, f]privateMatrix<double>transformMatrix;publicstructPointF{publicfloatX;publicfloatY;publicPointF(floatx,floaty){X=x;Y=y;}}// 添加标定点publicvoidAddCalibrationPoint(PointFimagePoint,PointFrobotPoint){calibrationPoints.Add((imagePoint,robotPoint));}// 执行标定计算publicboolCalculateCalibration(){if(calibrationPoints.Count<3){Console.WriteLine("至少需要3个标定点");returnfalse;}// 构建矩阵方程 A * params = B// 参数矩阵 params = [a, b, c, d, e, f]^Tintn=calibrationPoints.Count;Matrix<double>A=Matrix<double>.Build.Dense(2*n,6);Matrix<double>B=Matrix<double>.Build.Dense(2*n,1);for(inti=0;i<n;i++){var(image,robot)=calibrationPoints[i];// 填充A矩阵 - X坐标相关行A[2*i,0]=image.X;// xA[2*i,1]=image.Y;// yA[2*i,2]=1;// 1A[2*i,3]=0;A[2*i,4]=0;A[2*i,5]=0;// 填充A矩阵 - Y坐标相关行A[2*i+1,0]=0;A[2*i+1,1]=0;A[2*i+1,2]=0;A[2*i+1,3]=image.X;// xA[2*i+1,4]=image.Y;// yA[2*i+1,5]=1;// 1// 填充B矩阵B[2*i,0]=robot.X;B[2*i+1,0]=robot.Y;}// 使用最小二乘法求解try{// A * params = B => params = (A^T * A)^-1 * A^T * BvarAtA=A.Transpose()*A;varAtA_inv=AtA.Inverse();varAtB=A.Transpose()*B;varparamsVector=AtA_inv*AtB;// 转换为2x3变换矩阵transformMatrix=Matrix<double>.Build.Dense(2,3);transformMatrix[0,0]=paramsVector[0,0];// atransformMatrix[0,1]=paramsVector[1,0];// btransformMatrix[0,2]=paramsVector[2,0];// ctransformMatrix[1,0]=paramsVector[3,0];// dtransformMatrix[1,1]=paramsVector[4,0];// etransformMatrix[1,2]=paramsVector[5,0];// freturntrue;}catch(Exceptionex){Console.WriteLine($"标定计算失败:{ex.Message}");returnfalse;}}// 图像坐标转机械手坐标publicPointFImageToRobot(PointFimagePoint){if(transformMatrix==null){thrownewInvalidOperationException("尚未执行标定计算");}// 构建输入向量 [x, y, 1]Vector<double>input=Vector<double>.Build.Dense(new[]{imagePoint.X,imagePoint.Y,1.0});// 计算输出 [X, Y]Vector<double>output=transformMatrix*input;returnnewPointF((float)output[0],(float)output[1]);}// 机械手坐标转图像坐标(逆变换)publicPointFRobotToImage(PointFrobotPoint){if(transformMatrix==null){thrownewInvalidOperationException("尚未执行标定计算");}// 仿射变换的逆变换需要计算矩阵的逆Matrix<double>invTransform=Matrix<double>.Build.Dense(3,3);invTransform[0,0]=transformMatrix[0,0];invTransform[0,1]=transformMatrix[0,1];invTransform[0,2]=transformMatrix[0,2];invTransform[1,0]=transformMatrix[1,0];invTransform[1,1]=transformMatrix[1,1];invTransform[1,2]=transformMatrix[1,2];invTransform[2,0]=0;invTransform[2,1]=0;invTransform[2,2]=1;try{varinv=invTransform.Inverse();Vector<double>input=Vector<double>.Build.Dense(new[]{robotPoint.X,robotPoint.Y,1.0});Vector<double>output=inv*input;returnnewPointF((float)output[0],(float)output[1]);}catch{Console.WriteLine("逆变换计算失败,可能矩阵不可逆");returnnewPointF(0,0);}}}}

二 使用

usingSystem;usingSystem.Collections.Generic;usingSystem.ComponentModel;usingSystem.Data;usingSystem.Drawing;usingSystem.Linq;usingSystem.Text;usingSystem.Threading.Tasks;usingSystem.Windows.Forms;namespace平移标定的数学公式{publicpartialclassForm1:Form{publicForm1(){InitializeComponent();}privatevoidbutton1_Click(objectsender,EventArgse){varcalibrator=newCoordinateCalibration();// 添加9个标定点(示例数据,实际应用中需要真实测量)// 格式:(图像坐标X, 图像坐标Y), (机械手坐标X, 机械手坐标Y)calibrator.AddCalibrationPoint(newCoordinateCalibration.PointF(1588.7726f,596.46368f),newCoordinateCalibration.PointF(140,10));calibrator.AddCalibrationPoint(newCoordinateCalibration.PointF(2092.5125f,601.88007f),newCoordinateCalibration.PointF(140,-10));calibrator.AddCalibrationPoint(newCoordinateCalibration.PointF(2599.6616f,608.51514f),newCoordinateCalibration.PointF(140,-30));calibrator.AddCalibrationPoint(newCoordinateCalibration.PointF(1586.8936f,1092.2368f),newCoordinateCalibration.PointF(160,10));calibrator.AddCalibrationPoint(newCoordinateCalibration.PointF(2088.5759f,1099.787f),newCoordinateCalibration.PointF(160,-10));calibrator.AddCalibrationPoint(newCoordinateCalibration.PointF(2588.5093f,1111.1132f),newCoordinateCalibration.PointF(160,-30));calibrator.AddCalibrationPoint(newCoordinateCalibration.PointF(1573.5547f,1592.8459f),newCoordinateCalibration.PointF(180,10));calibrator.AddCalibrationPoint(newCoordinateCalibration.PointF(2082.4187f,1601.0065f),newCoordinateCalibration.PointF(180,-10));calibrator.AddCalibrationPoint(newCoordinateCalibration.PointF(2583.4763f,1615.3347f),newCoordinateCalibration.PointF(180,-30));// 执行标定计算if(calibrator.CalculateCalibration()){// 测试转换vartestImagePoint=newCoordinateCalibration.PointF(1200,1500);varrobotPoint=calibrator.ImageToRobot(testImagePoint);MessageBox.Show($"图像坐标({testImagePoint.X},{testImagePoint.Y}) -> 机械手坐标({robotPoint.X},{robotPoint.Y})");// 测试逆转换varbackToImage=calibrator.RobotToImage(robotPoint);MessageBox.Show($"机械手坐标({robotPoint.X},{robotPoint.Y}) -> 图像坐标({backToImage.X},{backToImage.Y})");}}}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/20 20:48:00

TOTOLINK EX200存在未修复固件漏洞可被完全远程接管

CERT协调中心(CERT/CC)披露了影响TOTOLINK EX200无线信号扩展器的未修复安全漏洞详情&#xff0c;该漏洞可能允许经过身份验证的远程攻击者完全控制设备。该漏洞编号为CVE-2025-65606(CVSS评分&#xff1a;暂无)&#xff0c;被描述为固件上传错误处理逻辑中的缺陷&#xff0c;可…

作者头像 李华
网站建设 2026/5/22 21:54:11

Ring推出Fire Watch功能,利用家庭摄像头追踪野火威胁

洛杉矶大火一年后&#xff0c;亚马逊Ring安防服务宣布推出名为Fire Watch的新功能&#xff0c;旨在减轻未来野火风险。Fire Watch与CES 2026同期发布&#xff0c;是Ring应用程序Neighbors社区安全更新板块的新功能&#xff0c;计划今年春季在全国范围内推出。Fire Watch依托Wat…

作者头像 李华
网站建设 2026/5/30 2:58:18

机器海龟游向环保使命:仿生技术守护珊瑚礁

在自然环境中与海龟一起游泳是一种令人敬畏的体验。这些温和的生物以其深思熟虑且小心的鳍状肢划水方式在水下世界中航行&#xff0c;观看起来完全令人着迷。这是一种独特的运动方式——当我在CES 2026展会现场看到Beatbot公司的RoboTurtle在水箱中游泳时&#xff0c;我立刻意识…

作者头像 李华
网站建设 2026/5/19 17:30:05

零基础 | LangChain 构建大模型应用的开发框架

文章目录&#x1f4c4; 基本信息&#x1f680; LangChain框架概述核心定位生态系统核心价值使用建议选择考量&#x1f9e9; LangChain核心抽象详解核心抽象组件ChatModel详解PromptTemplate详解OutputParser详解核心抽象的价值&#x1f4dd; 使用示例运行结果&#x1f3af; 功能…

作者头像 李华
网站建设 2026/5/22 2:23:25

基于STM32的智能语音台灯系统设计与实现

基于STM32的智能语音台灯系统设计与实现摘要随着物联网技术的快速发展和人们生活水平的不断提高&#xff0c;智能家居产品正逐渐融入人们的日常生活。作为家居环境中不可或缺的照明设备&#xff0c;传统台灯功能单一、操作不便&#xff0c;已难以满足现代人对便捷、健康、智能化…

作者头像 李华