Mujoco 仿真相机下 SolvePnp 获得 Apriltag 位姿

视频讲解:https://www.bilibili.com/video/BV1PTwTzUEq5/?vd_source=5ba34935b7845cd15c65ef62c64ba82f

代码仓库:https://github.com/LitchiCheng/mujoco-learning

上期视频《Mujoco 仿真棋格盘标定相机内参方法》中我们得到了相机的内参,结合之前Apriltag的标签获取,今天介绍一下在Mujoco的相机视野下通过solvepnp计算得到apriltag的位姿。

参考 https://docs.opencv.ac.cn/4.11.0/d5/d1f/calib3d_solvePnP.html 使用opencv的solvepnp,首先需要传入内参,畸变参数,tag的大小

原理:得到在相机坐标系下的位姿和在世界坐标系下的位姿,一般情况下是无法得到两个坐标系的变换关系,有无穷种解,但当描述的物体是同一个或已知物体之间的变换干系,那么就可以根据如下

安装cv2,uv pip install cv2 即可

复制代码
TAG_SIZE = 0.1 
# 格式:[[fx, 0, cx], [0, fy, cy], [0, 0, 1]]
# fx/fy: 焦距, cx/cy: 主点坐标
CAMERA_MATRIX = np.array([
    [415.019, 0.0, 318.59934938],
    [0.0, 415.294660431, 242.1195262],
    [0.0, 0.0, 1.0] 
], dtype=np.float32)
DIST_COEFFS = np.array([-0.00201 , 0.00547 ,-0.0003586  ,-0.00020906 ,-0.00284597], dtype=np.float32)
self.spnp = solvepnp.SolvePnp(TAG_SIZE, CAMERA_MATRIX, DIST_COEFFS)

然后通过getFixedCameraImage就得到相机视野下的bgr图,传入给solvepnp的计算方法中,循环中已经配置了键盘的控制,可以通过移动观察计算出的位置是否基本相近

复制代码
self.setMocapPosition("apriltag_0", [self.apriltag_pos_x, self.apriltag_pos_y, self.apriltag_pos_z])
image = self.getFixedCameraImage(fix_elevation=-90)
# print(self.model.cam_ipd)
if image is None:
    pass
else:
    _,_,_,transform = self.spnp.compute(image, 0)
    self.spnp.show()
    print(transform)

当然pnp的方法遇到的情况和使用的具体算法有很多,代码中只用到了一种情况做了封装

复制代码
# SOLVEPNP_IPPE_SQUARE 适合正方形标签,精度更高
success, rvec, tvec = cv2.solvePnP(
    self.obj_points, 
    img_points, 
    self.camera_intrinsic, 
    self.camera_distort,
    flags=cv2.SOLVEPNP_IPPE_SQUARE
)
  • SOLVEPNP_ITERATIVE:基于Levenberg-Marquardt(LM)迭代优化,至少 4 个有效点,重投影误差迭代
  • SOLVEPNP_EPNP:支持 ≥4 个点,适合多标签 / 多特征点的场景,解算效率高
  • SOLVEPNP_SQPNP:支持 ≥3 个点即可解算,无初值要求,适合标签被遮挡、仅提取到 3 个角点的场景

最终输出为apriltag在相机坐标系下的4*4的齐次变换矩阵

如图,apriltag位置相对于相机,x=0.00176,y=-0.00255,z=0.512,和mujoco 中配置的位置基本一致

相关推荐
普通网友6 小时前
阿里云国际版服务器,真的是学生党的性价比之选吗?
后端·python·阿里云·flask·云计算
模拟器连接器曾工6 小时前
CCD定位与图像辨别的智能视觉检测系统
人工智能·计算机视觉·视觉检测·智能视觉检测系统
云栖梦泽6 小时前
AI安全合规与治理:行业发展趋势与职业展望
大数据·人工智能·安全
小陈工6 小时前
2026年4月2日技术资讯洞察:数据库融合革命、端侧AI突破与脑机接口产业化
开发语言·前端·数据库·人工智能·python·安全
陈晓明start6 小时前
【python】豆包模型,自动生成测试用例初探索
python
happyprince7 小时前
2026年04月07日热门模型
人工智能
阿kun要赚马内7 小时前
Python中元组和列表差异:底层结构分析
开发语言·python
IT_陈寒7 小时前
Vue的这个响应式问题,坑了我整整两小时
前端·人工智能·后端
HIT_Weston7 小时前
41、【Agent】【OpenCode】本地代理分析(五)
javascript·人工智能·opencode