在 Python 中可视化四元数
我在无人机上安装了一个 IMU,每 0.1 秒收集一次四元数数据 (w,x,y,z)。现在我想将四元数数据与实际的无人机方向(视频数据)进行比较。
所以我想创建某种盒子对象来显示基于四元数数据的方向。
我实现了本教程,该教程将转换将四元数转换为欧拉以进行可视化。
有没有一种方法可以直接可视化四元数数据,而不需要先将其转换为欧拉?我觉得这应该是可能的,但我不确定如何实现。
I mounted an IMU on a drone which collected quaternion data (w,x,y,z) every 0.1s. Now I want to compare the quaternion data to the actual drone orientation (video data).
So I would like to create some sort of box object that shows the orientation based on the quaternion data.
I implemented this tutorial which converts the quaternions to Euler for visualization.
Is there a way to directly visualize quaternion data, without converting it to Euler first? I feel like this should be possible, but I am not sure how.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您可以将四元数可视化,而无需将其转换为欧拉角。四元数只不过是 3D 空间中的一个复数,但它不是沿着 i 具有一个虚部,而是沿着 i、j 和 k 具有三个虚部。因此,您可以使用它来旋转 3D 参考位置向量,就像您在 2D 中使用复数进行旋转一样,而不依赖于其角度。
在下面的代码中,我创建了一个 IMU 四元数示例,对应横滚 = 5°、俯仰 = 45° 和横滚 = 30°。我使用这个四元数来旋转 3 个点(位置向量),这些点代表与地球相关的笛卡尔坐标系的单位向量。因此,3 个变换点代表与无人机相关的机身框架的单位向量。这些矢量显示了当前无人机的姿态。您需要对
att
四元数做的就是:使用一些约定(您可能需要根据您的特定需求更改它们):
为了减轻四元数相乘的负担,我使用了一个模块将四元数添加到 Numpy(您可以在 此处)。
输出:
蓝色为地球框架 (NED),红色为无人机框架(机身框架) 您可以用更直观的飞机轮廓替换这 3 个点。
首先,我需要创建 IMU 样本,您不必这样做,而是使用 IMU 输出:
地球框架单位向量的头:
这些点被旋转。旋转涉及四元数积,格式为
rotated = q * point * q'
,其中q'
是q
的倒数,在本例中共轭(调整代码以在循环中处理 IMU 四元数)。绘制两个框架,地球为蓝色,旋转(身体)为红色。
You can visualize quaternions without converting them to Euler's angles. A quaternion is no more than a complex number in 3D space, but instead of having one imaginary part along i, it has three imaginary parts along i, j and k. So you can use it to rotate 3D reference position vectors, like you would do it in 2D with a complex number without relying on its angle.
In the code below, I create an example of IMU quaternion corresponding to roll = 5°, pitch = 45° and roll = 30°. I use this quaternion to rotate 3 points (position vectors) which represent the unit vectors of a Cartesian frame associated with Earth. Therefore the 3 transformed points represent the unit vectors of a body-frame associated with the drone. These vectors show the current drone attitude. All you have to do with your
att
quaternion is:Some conventions used (you may have to change them for your specific needs):
To save the burden of multiplying quaternions, I used a module to add quaternions to Numpy (you can find it here).
The output:
In blue the Earth frame (NED), in red the drone frame (body-frame) You can replace the 3 points by a more visual aircraft silhouette.
First I need to create the IMU sample, you don't have to do this, use you IMU output instead:
The heads of Earth-frame unit vectors:
These points are rotated. The rotation involves a quaternion product in the form
rotated = q * point * q'
whereq'
is the inverse ofq
, in this case the conjugate (adjust the code to process your IMU quaternions in a loop).Plot the two frames, Earth in blue, rotated (body) in red.