【机器人3】图像雅可比矩阵原理与推导

news2024/11/28 10:58:56

图像雅可比矩阵原理与推导

理想情况下,图像像素坐标系和图像物理坐标系无倾斜,则二者坐标转换关系如下,且两边求导:
在这里插入图片描述
[ u v 1 ] = [ 1 d x 0 u 0 0 1 d y v 0 0 0 1 ] [ x y 1 ] (1) \begin{bmatrix}u\\v\\1\end{bmatrix}=\begin{bmatrix}\frac{1}{d_x}&0&u_0\\0&\frac{1}{d_y}&v_0\\0&0&1\end{bmatrix}\begin{bmatrix}x\\y\\1\end{bmatrix} \tag{1} uv1 = dx1000dy10u0v01 xy1 (1) { u ˙ = 1 d x x ˙ v ˙ = 1 d y y ˙ (2) \begin{cases}\dot{u}=\frac{1}{d_x}\dot{x}\\ \dot{v}=\frac{1}{d_y}\dot{y}\end{cases} \tag{2} {u˙=dx1x˙v˙=dy1y˙(2)由小孔成像原理,空间一点的相机坐标和图像物理坐标转换关系如下,且两边求导:在这里插入图片描述 [ x y 1 ] = [ f Z c 0 0 0 f Z c 0 0 0 1 Z c ] [ X c Y c Z c ] (3) \begin{bmatrix}x\\ y\\ 1\end{bmatrix}=\begin{bmatrix}\frac{f}{Z_c}&0&0\\ 0&\frac{f}{Z_c}&0\\ 0&0&\frac{1}{Z_c}\end{bmatrix}\begin{bmatrix}X_c\\ Y_c\\ Z_c\end{bmatrix} \tag{3} xy1 = Zcf000Zcf000Zc1 XcYcZc (3) { x ˙ = f ( X ˙ c Z c − X c Z ˙ c Z c 2 ) = f X ˙ c Z c − x Z ˙ c Z c y ˙ = f ( Y ˙ c Z c − Y c Z ˙ c Z c 2 ) = f Y ˙ c Z c − y Z ˙ c Z c (4) \begin{cases}\dot{x}=f(\frac{\dot{X}_c}{Z_c}-\frac{X_c\dot{Z}_c}{Z_c^2})=\frac{f\dot{X}_c}{Z_c}-\frac{x\dot{Z}_c}{Z_c}\\ \dot{y}=f(\frac{\dot{Y}_c}{Z_c}-\frac{Y_c\dot{Z}_c}{Z_c^2})=\frac{f\dot{Y}_c}{Z_c}-\frac{y\dot{Z}_c}{Z_c}\end{cases} \tag{4} {x˙=f(ZcX˙cZc2XcZ˙c)=ZcfX˙cZcxZ˙cy˙=f(ZcY˙cZc2YcZ˙c)=ZcfY˙cZcyZ˙c(4)固定相机,移动空间点时,速度关系为: p ˙ c = c v p + c ω p × p c (5) \dot{\boldsymbol{p}}_c =^c\boldsymbol{v}_p +^c\boldsymbol{\omega}_p\times\boldsymbol{p}_c\tag{5} p˙c=cvp+cωp×pc(5)固定空间点,移动相机时,速度关系为: p ˙ c = − c v c − c ω c × p c (6) \dot{\boldsymbol{p}}_c = -^c\boldsymbol{v}_c -^c\boldsymbol{\omega}_c\times\boldsymbol{p}_c\tag{6} p˙c=cvccωc×pc(6) { X ˙ c = − c ν c , x − c ω c , y Z c + c ω c , z Y c Y ˙ c = − c ν c , y − c ω c , z X c + c ω c , x Z c Z ˙ c = − c ν c , z − c ω c , x Y c + c ω c , y X c (7) \begin{cases}\dot{X}_c=-{}^c\nu_{c,x}-{}^c\omega_{c,y}Z_c+{}^c\omega_{c,z}Y_c\\ \dot{Y}_c=-{}^c\nu_{c,y}-{}^c\omega_{c,z}X_c+{}^c\omega_{c,x}Z_c\\ \dot{Z}_c=-{}^c\nu_{c,z}-{}^c\omega_{c,x}Y_c+{}^c\omega_{c,y}X_c\end{cases}\tag{7} X˙c=cνc,xcωc,yZc+cωc,zYcY˙c=cνc,ycωc,zXc+cωc,xZcZ˙c=cνc,zcωc,xYc+cωc,yXc(7)将(7)代入(4),得: { x ˙ = − f Z c c v c , x + x Z c c v c , z + x y f c ω c , x − f 2 + x 2 f c ω c , y + y c ω c , z y ˙ = − f Z c c v c , y + y Z c c v c , z + f 2 + y 2 f c ω c , x − x y f c ω c , y − x c ω c , z (8) \left\{\begin{array}{l} \dot{x}=-\frac{f}{Z_{c}}{ }^{c} v_{c, x}+\frac{x}{Z_{c}}{ }^{c} v_{c, z}+\frac{x y}{f}{ }^{c} \omega_{c, x}-\frac{f^{2}+x^{2}}{f}{ }^{c} \omega_{c, y}+y^{c} \omega_{c, z} \\ \dot{y}=-\frac{f}{Z_{c}}{ }^{c} v_{c, y}+\frac{y}{Z_{c}}{ }^{c} v_{c, z}+\frac{f^{2}+y^{2}}{f}{ }^{c} \omega_{c, x}-\frac{x y}{f}{ }^{c} \omega_{c, y}-x^{c} \omega_{c, z} \end{array}\right.\tag{8} {x˙=Zcfcvc,x+Zcxcvc,z+fxycωc,xff2+x2cωc,y+ycωc,zy˙=Zcfcvc,y+Zcycvc,z+ff2+y2cωc,xfxycωc,yxcωc,z(8)即: [ x ˙ y ˙ ] = [ − f Z c 0 x Z c x y f − f 2 + x 2 f y 0 − f Z c y Z c f 2 + y 2 f − x y f − x ] [ c v c , x c v c , y c v c , z c ω c , x c ω c , y c ω c , z ] (9) \begin{bmatrix}\dot{x}\\ \dot{y}\end{bmatrix}=\begin{bmatrix}-\frac{f}{Z_c}&0&\frac{x}{Z_c}&\frac{xy}{f}&-\frac{f^2+x^2}{f}&y\\ 0&-\frac{f}{Z_c}&\frac{y}{Z_c}&\frac{f^2+y^2}{f}&-\frac{xy}{f}&-x\end{bmatrix}\left[\begin{array}{l} { }^{c} v_{c, x} \\ { }^{c} v_{c, y} \\ { }^{c} v_{c, z} \\ { }^{c} \omega_{c, x} \\ { }^{c} \omega_{c, y} \\ { }^{c} \omega_{c, z} \end{array}\right]\tag{9} [x˙y˙]=[Zcf00ZcfZcxZcyfxyff2+y2ff2+x2fxyyx] cvc,xcvc,ycvc,zcωc,xcωc,ycωc,z (9)将(9)以及 x = d x ( u − u 0 ) x=d_{x}\left(u-u_{0}\right) x=dx(uu0) y = d y ( v − v 0 ) y=d_y(v-v_0) y=dy(vv0)代入(2): [ u ˙ v ˙ ] = [ − f d x Z c 0 ( u − u 0 ) Z c ( u − u 0 ) d y ( v − v 0 ) f − f 2 + d x 2 ( u − u 0 ) 2 d x f d y ( v − v 0 ) d x 0 − f d y Z c ( v − v 0 ) Z c f 2 + d y 2 ( v − v 0 ) 2 d y f − d x ( u − u 0 ) ( v − v 0 ) f − d x ( u − u 0 ) d y ] [ c v c , x c v c , y c v c , z c ω c , x c ω c , y c ω c , z ] (10) \left[\begin{array}{c} \dot{u} \\ \dot{v} \end{array}\right]=\left[\begin{array}{cccccc} -\frac{f}{d_{x} Z_{c}} & 0 & \frac{\left(u-u_{0}\right)}{Z_{c}} & \frac{\left(u-u_{0}\right) d_{y}\left(v-v_{0}\right)}{f} & -\frac{f^{2}+d_{x}^{2}\left(u-u_{0}\right)^{2}}{d_{x} f} & \frac{d_{y}\left(v-v_{0}\right)}{d_{x}} \\ 0 & -\frac{f}{d_{y} Z_{c}} & \frac{\left(v-v_{0}\right)}{Z_{c}} & \frac{f^{2}+d_{y}^{2}\left(v-v_{0}\right)^{2}}{d_{y} f} & -\frac{d_{x}\left(u-u_{0}\right)\left(v-v_{0}\right)}{f} & -\frac{d_{x}\left(u-u_{0}\right)}{d_{y}} \end{array}\right]\left[\begin{array}{l} { }^{c} v_{c, x} \\ { }^{c} v_{c, y} \\ { }^{c} v_{c, z} \\ { }^{c} \omega_{c, x} \\ { }^{c} \omega_{c, y} \\ { }^{c} \omega_{c, z} \end{array}\right] \tag{10} [u˙v˙]= dxZcf00dyZcfZc(uu0)Zc(vv0)f(uu0)dy(vv0)dyff2+dy2(vv0)2dxff2+dx2(uu0)2fdx(uu0)(vv0)dxdy(vv0)dydx(uu0) cvc,xcvc,ycvc,zcωc,xcωc,ycωc,z (10)即: [ u ˙ v ˙ ] = J i m g [ c v c c u c ] (11) \begin{bmatrix}\dot{u}\\ \dot{v}\end{bmatrix}=J_{img}\begin{bmatrix}^c\boldsymbol{v}_{c}\\^c \boldsymbol{u}_{c}\end{bmatrix}\tag{11} [u˙v˙]=Jimg[cvccuc](11)可得图像雅可比矩阵: J i m g = [ − f d x Z c 0 ( u − u 0 ) Z c ( u − u 0 ) d y ( v − v 0 ) f − f 2 + d x 2 ( u − u 0 ) 2 d x f d y ( v − v 0 ) d x 0 − f d y Z c ( v − v 0 ) Z c f 2 + d y 2 ( v − v 0 ) 2 d y f − d x ( u − u 0 ) ( v − v 0 ) f − d x ( u − u 0 ) d y ] (12) J_{img}=\left[\begin{array}{cccccc} -\frac{f}{d_{x} Z_{c}} & 0 & \frac{\left(u-u_{0}\right)}{Z_{c}} & \frac{\left(u-u_{0}\right) d_{y}\left(v-v_{0}\right)}{f} & -\frac{f^{2}+d_{x}^{2}\left(u-u_{0}\right)^{2}}{d_{x} f} & \frac{d_{y}\left(v-v_{0}\right)}{d_{x}} \\ 0 & -\frac{f}{d_{y} Z_{c}} & \frac{\left(v-v_{0}\right)}{Z_{c}} & \frac{f^{2}+d_{y}^{2}\left(v-v_{0}\right)^{2}}{d_{y} f} & -\frac{d_{x}\left(u-u_{0}\right)\left(v-v_{0}\right)}{f} & -\frac{d_{x}\left(u-u_{0}\right)}{d_{y}} \end{array}\right]\tag{12} Jimg= dxZcf00dyZcfZc(uu0)Zc(vv0)f(uu0)dy(vv0)dyff2+dy2(vv0)2dxff2+dx2(uu0)2fdx(uu0)(vv0)dxdy(vv0)dydx(uu0) (12)如有不足之处欢迎指出~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/646690.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言-变量

1 内存的分区 1、内存:物理内存、虚拟内存 物理内存:实实在在存在的存储设备 虚拟内存:操作系统虚拟出来的内存。 操作系统会在物理内存和虚拟内存之间做映射。 在32位系统下,每个进程的寻址范围是4G,0x00 00 00 00 ~0xff ff …

和想要通过学习 Python 转行的同学聊一聊

在开始之前我想说,关于这类话题,永远会存在分歧和争论。比如有人看好互联网发展,有人说泡沫太大;有人说要做项目,有人说得多刷题;有人说要去培训班,有人说不如自学;有人说你学 Pytho…

【MySql】基本查询

文章目录 插入操作insert查询操作selectselect查询where条件判断order by排序limit筛选分页结果 更新操作update删除操作delete插入查询结果 CRUD : Create(创建), Retrieve(读取),Update(更新),Delete(删除) 先创建提供一张表&am…

给大家分享一份适合练手的软件测试实战项目

我们都知道软件测试是一个理论性强的分支。 正是这种特点,决定了在学习的过程中不单单是看或者去背相应的知识点,而是真真切切的基于这些理论基础知识,结合实战项目进行演练。这也就是所谓的眼过千遍不如手过一遍。而且大家也都能看到&#…

13. 100ASK-V853-PRO开发板 摄像头测试指南

100ASK-V853-PRO开发板 摄像头测试指南 硬件要求: 100ASK-V853-PRO开发板GC2053摄像头 软件要求: 固件下载地址:链接:百度网盘 提取码:sp6a 固件位于资料光盘中的10_测试镜像/3.测试摄像头/v853_linux_100ask_uart0…

119.【Uniapp】

uni-app (一)、uni-app 起步1.Uniapp简介2.Uniapp开发工具(1).下载HbuilderX(2).安装scss/sass编译(3).快捷键方案切换(4).修改编辑器的基本设置 3.新建 uni-app项目4.uniapp 的目录结构5.把项目运行到微信开发者工具中(1).填写自己的微信小程序的AppID:(2).在HBuilderX中&…

java循环语句

文章目录 for循环while循环do-while循环嵌套循环关键字break和continue的使用break带标签的使用 for循环 语法格式: for (①初始化部分; ②循环条件部分; ④迭代部分){③循环体部分; }说明: for(;;)中的两个;不能多…

视觉SLAM十四讲——ch7实践(视觉里程计1)

视觉SLAM十四讲----ch7的实践操作及避坑 1. 实践操作前的准备工作2. 实践过程2.1 特征提取与匹配2.2 对极几何2.3 三角测量2.4 求解PnP2.5 求解ICP 3. 遇到的问题3.1 准备工作遇到的问题 1. 实践操作前的准备工作 在终端中进入ch7文件夹下,顺序执行以下命令进行编译…

Sentinel的限流和Gateway的限流差别?

Sentinel的限流与Gateway的限流有什么差别? 问题说明:考察对限流算法的掌握情况 限流算法常见的有三种实现:滑动时间窗口,令牌桶算法,漏桶算法。gateway则采用基于Redis实现的令牌桶算法。但是我们不会去用&#xff…

PCB做了盲埋孔,还有必要再做盘中孔工艺吗

一博高速先生成员--王辉东 初夏的西湖美艳无边,若不去看看人生总觉遗憾。 杭州两大美女明明和琪琪约好这个星期天,一起去西湖转转,到灵隐寺许个愿,再到北高峰爬个山。 话说两人正行之间,看到正对面也有两个美女结伴同…

Spring Security Oauth2.1 最新版 1.1.0 整合 gateway 完成授权认证(基于 springboot 3.1)

目录 背景 版本 Spring Boot 3.1 Spring Authorization Server 1.1.0官方文档 基础 spring security OAuth2.0 模块构成 授权方式 集成过程 官方demo 代码集成 依赖 授权服务AuthorizationServerConfig配置 重要组件 测试 查看授权服务配置 访问授权服务 授…

渗透测试与自动化安全测试工具比较

应用程序安全性并不新鲜,但它在需求、复杂性和深度方面正迅速增长。随着网络犯罪自疫情爆发以来增长了近600%,越来越多的SaaS企业开始争相保护他们的应用程序。即使那些运行最新端点保护的系统也面临重大漏洞。 然而随之而来的一个问题是:即…

【javaweb+springboot】旅游网页面设计(主购物车功能)——前后端分离+服务端客户端增删改查(完整代码+文档)

一、项目背景 由于疫情原因,张家界旅游业受到很大的影响,为了促进旅游业的发展,吸引更多游客来到张家界旅游,帮助游客更好地了解张家界,创建张家界旅游网,推进旅游发展大会的开展,展示当地风土人…

商城系统功能有哪些?

商城系统是一种以电子商务为基础的技术工具,为企业涉足电子商务提供了完整的解决方案。商城系统不仅可以帮助企业降低成本,提高效率,还可以实现全方位的在线营销,为企业争取更多的竞争优势,如SHOP、Magento等一系列成熟…

EBU5476 Microprocessor System Design 知识点总结_3 Assembly

Assembly 汇编语法。 顺序结构 label ; 可省略,用于跳转到此位置助记符 operand1, operand2, … ; CommentsMOV r1, #0x01 ; 数据0x01放入r1 MOV r1, #A ; 数据A的ascii码放入r1 MOV R0, R1 ; move R1 into R0 MOVS R0, R1 ; move R1 i…

当 GraphQL 遇上图数据库,便有了更方便查询数据的方式

人之初,性本鸽。 大家好,我叫储惠龙(实名上网),你可以叫我小龙人,00 后一枚。目前从事后端开发工作。 今天给大家带来一个简单的为 NebulaGraph 提供 GraphQL 查询支持的 DEMO,为什么是简单的…

职业教育机构转线上时,选择平台要注意哪些方面?

职业教育是提升技能和知识的重要途径,有效的职业教育能够帮助培养和发展人才,相比较线下面授课程相比,在线直播的教学,可以节省较大成本,那么在选型直播平台时,要注意哪些方面呢? 1.需要实现高清…

记录一次使用__dirname和./引出的bug

JS项目中 保存本地生成的图片时使用的路径:__dirname“/waitToFinishTask.png"。 但是在获取这张图片的时候我使用的是“./waitToFinishTask.png”。 从而抛出异常:Error: ENOENT, No such file or directory ./waitToFinishTask.png 找了好久都不知道为什么会…

【无标题】windows下使用cmake编译c++

好久没有更新博客了 最近在做c相关的,编译起来确实很痛苦。 所以心血来潮,继续更新一下 主要还是一些跨平台的库,比如zlib、libpng、opencv、ffmpeg 编译工具使用mingw作为主要编译环境支持,使用msys进行编译。 一、下载mingw…

利用etcd实现分布式锁

python etcd3模块的lock使用 观察lock的加解锁影响 在python中已经自带了分布式锁的实现方式,下面我们尝试一下加锁与解锁的流程 在运行该demo同时也对lock对应的key进行watch,观察其变化,注意python-etcd3在实现分布式锁的时候&#xff0…