【学习笔记】Sophus (Python) 使用文档

以下是一份针对 Sophus 库的 Python 使用文档,涵盖基础概念、安装方法、核心功能及代码示例。内容围绕 SO3(3D旋转群)和 SE3(3D刚体变换群)展开,适合机器人学、SLAM、三维几何等领域。


Sophus (Python) 使用文档

目录

  1. Sophus 简介
  2. 安装方法
  3. 核心对象与操作
    • SO3:3D旋转群
    • SE3:3D刚体变换群
  4. 常用功能与示例
    • 创建旋转/变换对象
    • 转换不同表示形式
    • 位姿插值(Slerp/Lerp)
    • 李代数与指数映射
    • 逆变换与组合变换
  5. 注意事项
  6. 完整代码示例

1. Sophus 简介

Sophus 是一个用于处理 李群(Lie Groups) 的C++/Python库,支持 SO2/SE2(2D旋转/变换)和 SO3/SE3(3D旋转/变换)。

  • 核心功能
    • 旋转与变换的表示(四元数、旋转矩阵、轴角、李代数等)
    • 李群与李代数的相互转换(指数/对数映射)
    • 位姿插值(Slerp)、逆变换、组合变换
  • 适用场景:机器人运动学、SLAM、三维重建、姿态估计等。

2. 安装方法

通过 pip 安装 Sophus 的 Python 绑定(需提前安装 Eigen 库):

pip install sophus

3. 核心对象与操作

3.1 SO3 (3D旋转群)

表示三维空间中的旋转,支持四元数、旋转矩阵、轴角等表示形式。

创建 SO3对象
from sophus.so3 import SO3
import numpy as np# 从四元数创建 (w, x, y, z 顺序)
q = np.array([0.707, 0.0, 0.707, 0.0])  # 绕x轴旋转90度
so3_quat = SO3(q)# 从旋转矩阵创建
R = np.eye(3)
so3_rotmat = SO3.from_matrix(R)# 从轴角创建 (旋转向量,模长为旋转角度)
axis_angle = np.array([0, 0, np.pi/2])  # 绕z轴旋转90度
so3_axis_angle = SO3.exp(axis_angle)
转换表示形式
# 转为四元数 [w, x, y, z]
q = so3_axis_angle.quaternion()# 转为旋转矩阵 (3x3)
R = so3_axis_angle.matrix()# 转为轴角(李代数)
log = so3_axis_angle.log()  # 返回旋转向量

3.2 SE3 (3D刚体变换群)

表示三维空间中的刚体变换(旋转 + 平移),由 SO3 和 平移向量组成。

创建 SE3 对象
from sophus.se3 import SE3# 从旋转矩阵 + 平移向量创建
R = np.eye(3)
t = np.array([1.0, 2.0, 3.0])
se3_rotmat = SE3(R, t)# 从四元数 + 平移向量创建
q = np.array([0.707, 0.0, 0.707, 0.0])  # 绕x轴旋转90度
se3_quat = SE3(SO3(q), t)# 从变换矩阵 (4x4) 创建
T = np.eye(4)
T[:3, :3] = R
T[:3, 3] = t
se3_matrix = SE3.from_matrix(T)
转换表示形式
# 获取旋转部分 (SO3)
so3_part = se3_matrix.so3()# 获取平移部分 (3x1)
t_part = se3_matrix.translation()# 转为变换矩阵 (4x4)
T = se3_matrix.matrix()

4. 常用功能与示例

4.1 位姿插值(Slerp + Lerp)

SE3 中插值旋转(Slerp)和平移(Lerp):

def interpolate_se3(pose1, pose2, t):""" SE3 插值:旋转用 Slerp,平移用 Lerp """se3_1 = SE3.from_matrix(pose1)se3_2 = SE3.from_matrix(pose2)# 旋转插值 (SO3)so3_interp = SO3.slerp(se3_1.so3(), se3_2.so3(), t)# 平移插值 (Lerp)t_interp = (1 - t) * se3_1.translation() + t * se3_2.translation()return SE3(so3_interp, t_interp).matrix()# 示例:从 pose1 到 pose2 的中间位姿
pose_mid = interpolate_se3(pose1, pose2, 0.5)

4.2 李代数与指数映射

# 从李代数生成 SE3
se3 = SE3.exp(np.array([0.1, 0.2, 0.3, 0.4, 0.5, 0.6]))  # 前3维平移,后3维旋转# 从 SE3 提取李代数
lie_alg = se3.log()  # 6维向量 [t_x, t_y, t_z, ω_x, ω_y, ω_z]

4.3 逆变换与组合变换

# 逆变换
se3_inv = se3.inverse()# 组合变换:se3_new = se3_a * se3_b
se3_new = se3_a * se3_b

5. 注意事项

  1. 四元数顺序:Sophus 使用 [w, x, y, z] 顺序,与其他库(如PyTorch3D的xyzw)可能不同。
  2. 版本兼容性:Python 版 Sophus 功能可能比 C++ 版少,建议参考官方文档。
  3. 性能问题:Python 接口适合原型设计,性能关键场景建议使用 C++。

6. 完整代码示例

import numpy as np
from sophus.so3 import SO3
from sophus.se3 import SE3# 创建两个 SE3 位姿
pose1 = SE3(SO3.exp([0, 0, 0]), np.array([1, 2, 3]))
pose2 = SE3(SO3.exp([0, 0, np.pi/2]), np.array([4, 5, 6]))# 插值
pose_mid = interpolate_se3(pose1.matrix(), pose2.matrix(), 0.5)
print("插值后的变换矩阵:\n", pose_mid)# 计算相对变换
relative_pose = pose1.inverse() * pose2
print("相对变换的李代数:\n", relative_pose.log())

通过本文档,您可快速掌握 Sophus 库的核心功能,实现三维空间中的旋转、变换及插值操作。建议结合 Sophus 官方 GitHub 深入探索高级功能。

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

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

相关文章

计算机图形学:(三)MVP变换扩展

Three.js WebGL允许把JavaScript和OpenGL 结合在一起运用,但使用WebGL原生的API来写3D程序非常的复杂,同时需要相对较多的数学知识,对于前端开发者来说学习成本非常高。 Three.js是基于webGL的封装的一个易于使用且轻量级的3D库,T…

MySQL数据库操作合集

一、SQL通用语法 ①SQL语句可以单行或多行书写,以分号结尾。 ②SQL语句可以使用空格/缩进来增强语句可读性。 ③MySQL数据库的SQL语句不区分大小写,关键字建议使用大写。 ④注释: 单行注释: -- 注释内容 或 # 注释内容&#…

传统工程项目管理与业财一体化管理的区别?

在工程项目管理领域,传统管理模式与新兴的业财一体化管理模式正在形成鲜明对比。随着数字化转型的加速,工程行业对高效、透明、协同的管理需求日益迫切。传统工程项目管理依赖人工操作、分散系统和分模块管理,难以应对复杂项目的全生命周期需…

敦煌网测评从环境搭建到风控应对,精细化运营打造安全测评体系

自养号测评,抢占流量为快速提升产品权重和销量,很多卖家常采用自己养号补单测评的方式,技术搭建需要很多要素 一、硬件参数的关联性 在我们使用设备进行注册或操作账号的过程中,系统会记录下大量的系统与网络参数,其中…

redis Pub/Sub 简介 -16 (PUBLISH、SUBSCRIBE、PSUBSCRIBE)

Redis Pub/Sub 简介:PUBLISH、SUBSCRIBE、PSUBSCRIBE Redis Pub/Sub 是一种强大的消息传递范例,可在应用程序的不同部分之间实现实时通信。它是构建可扩展和响应式系统的基石,允许组件在没有直接依赖的情况下进行交互。本章将全面介绍 Redis…

JavaSE核心知识点03高级特性03-01(集合框架)

🤟致敬读者 🟩感谢阅读🟦笑口常开🟪生日快乐⬛早点睡觉 📘博主相关 🟧博主信息🟨博客首页🟫专栏推荐🟥活动信息 文章目录 JavaSE核心知识点03高级特性03-01&#xff0…

日志分析-IIS日志分析

环境准备 https://xj.edisec.net/challenges/115 题目要求 windows系统中才有的IIS服务 既然是windows平台,当然需要rdp登录,在ssh登录失败 解题过程 phpstudy--2018站点日志.(.log文件)所在路径,提供绝对路径 Windows服务的日志一般有固定…

一、web安全基础入门

1、Windows命令 文件和目录操作 dir:列出当前目录下的文件和子目录。cd:切换目录,例如 cd C:\Users 切换到C盘的Users目录。md 或 mkdir:创建新目录,如 md testdir。rd 或 rmdir:删除空目录,例…

动态规划应用场景 + 代表题目清单(模板加上套路加上题单)

1. 序列型DP(Sequence DP) ✅ 应用场景 单个或多个序列(数组/字符串),求最优子结构。 常见问题:最长递增子序列、最长公共子序列、回文子序列。 🧠 套路总结 单序列:dp[i] max(…

Linux iSCSI存储共享实验指南

实验介绍 1、在Linux平台上通过iSCSI协议实现IP-SAN存储共享 2、掌握存储导出(export)和存储导入(import)的配置方法 3、学习iSCSI存储的发现、连接、断开和管理操作 1、实验环境 两台同网段的Linux虚拟机(无需物理交换机) 操作系统:Lin…

从 Docker 到 runC

从 Docker 到 runC:容器底层原理详解 目录 1. Docker 与 runC 的关系 2. Docker 的核心组件 3. runC 的核心功能 4. 实战示例:从 Docker 到 runC 4.1 示例场景:运行一个简单容器 4.2 Docker 底层调用 runC 的流程 4.3 查看 runC 的调用 4.4 直接调用 runC 创建容器 …

使用Python在PowerPoint中插入形状(Shape)

在进行演示文稿设计时,形状(Shape)不仅可以增强视觉效果,还可以用于展示流程图、标注、数据图示等。借助Python,我们可以通过代码快速批量地在PPT中添加各种形状,提升设计效率。本文将介绍如何使用Python向…

Windows系统下MySQL 8.4.5压缩包安装详细教程

一、MySQL 8.4.5新特性概览 相较于旧版本,MySQL 8.4.5在性能与功能上实现了显著提升: 性能优化:官方测试显示,在高并发场景下,其读写性能较5.7版本提升近2倍,尤其在处理热点数据竞争问题时表现更为出色。…

深度解析Vue项目Webpack打包分包策略 从基础配置到高级优化,全面掌握性能优化核心技巧

深度解析Vue项目Webpack打包分包策略 从基础配置到高级优化,全面掌握性能优化核心技巧 一、分包核心价值与基本原理 1.1 为什么需要分包 首屏加载优化:减少主包体积,提升TTI(Time to Interactive)缓存利用率提升&am…

【昇腾开发者训练营:Dify大模型部署实战】MindIE + Dify + DeepSeek + Embedding模型 + Rerank模型

文章目录 部署 Dify1. Dify 适配 ARM2. 安装 docker3. 启动 Dify MindIEDify 实操手册1. 基础环境搭建1.1 环境检查1.2 下载模型权重1.3 获取MindIE镜像 2. 启动容器3. 纯模型推理测试3.1 纯模型对话测试3.2 性能测试 4. 服务化部署4.1 MindIE 配置4.2 MindIE 服务化4.3 发起测…

塔能高温冰蓄冷技术:工厂能耗精准节能的创新之路

在工厂的能耗构成中,制冷系统是重要的耗能环节。传统的水蓄冷和冰蓄冷技术在实际应用中存在一些局限性,难以满足工厂对节能和成本控制的更高要求。塔能科技的高温冰蓄冷技术,凭借其独特的优势,为工厂能耗精准节能提供了创新的解决…

通过现代数学语言重构《道德经》核心概念体系,形成一个兼具形式化与启发性的理论框架

以下是对《道德经》的数学转述尝试,通过现代数学语言重构其核心概念,形成一个兼具形式化与启发性的理论框架: 0. 基础公理体系 定义: 《道德经》是一个动态宇宙模型 U(D,V,Φ),其中: D 为“道”的无限维…

SQLMesh Typed Macros:让SQL宏更强大、更安全、更易维护

在SQL开发中,宏(Macros)是一种强大的工具,可以封装重复逻辑,提高代码复用性。然而,传统的SQL宏往往缺乏类型安全,容易导致运行时错误,且难以维护。SQLMesh 引入了 Typed Macros&…

5月23日day34打卡

GPU训练及类的call方法 知识点回归: CPU性能的查看:看架构代际、核心数、线程数GPU性能的查看:看显存、看级别、看架构代际GPU训练的方法:数据和模型移动到GPU device上类的call方法:为什么定义前向传播时可以直接写作…

集群、容器云与裸金属服务器的全面对比分析

文章目录 引言 集群 2.1 定义 2.2 特点 2.3 应用场景 容器云 3.1 定义 3.2 核心功能 3.3 应用场景 裸金属 4.1 定义 4.2 特点 4.3 应用场景 三者的区别 5.1 架构与性能 5.2 管理与运维 5.3 成本与灵活性 总结 1. 引言 在云计算和数据中心领域,50…