将机器人六轴坐标转为4*4矩阵(Opencv/C++)

已知机器人六轴坐标x,y,z,rx,ry,rz,其中xyz表示空间位置坐标,rx,ry,rz是欧拉角;

需要将这六个值转为4*4的矩阵以便后续其它处理运算。

代码如下:

#include <opencv2/core.hpp>
#include <iostream>
#include <cmath>

using namespace cv;
using namespace std;

// 将 xyz 和欧拉角转换为 4x4 矩阵
Mat xyzEulerToMatrix(double x, double y, double z, double rx, double ry, double rz) {
  // 转换为弧度
  rx = rx * CV_PI / 180.0;
  ry = ry * CV_PI / 180.0;
  rz = rz * CV_PI / 180.0;

  // 构建旋转矩阵
  Mat rotX = (Mat_<double>(3, 3) <<
    1.0, 0.0, 0.0,
    0.0, cos(rx), -sin(rx),
    0.0, sin(rx), cos(rx)
  );

  Mat rotY = (Mat_<double>(3, 3) <<
    cos(ry), 0.0, sin(ry),
    0.0, 1.0, 0.0,
    -sin(ry), 0.0, cos(ry)
  );

  Mat rotZ = (Mat_<double>(3, 3) <<
    cos(rz), -sin(rz), 0.0,
    sin(rz), cos(rz), 0.0,
    0.0, 0.0, 1.0
  );

  // 构建平移矩阵
  Mat translation = (Mat_<double>(4, 4) <<
    1.0, 0.0, 0.0, x,
    0.0, 1.0, 0.0, y,
    0.0, 0.0, 1.0, z,
    0.0, 0.0, 0.0, 1.0
  );

  // 旋转矩阵相乘
  Mat rotation = rotZ * rotY * rotX;

  // 合并旋转和平移
  Mat matrix = (Mat_<double>(4, 4) <<
    rotation.at<double>(0, 0), rotation.at<double>(0, 1), rotation.at<double>(0, 2), x,
    rotation.at<double>(1, 0), rotation.at<double>(1, 1), rotation.at<double>(1, 2), y,
    rotation.at<double>(2, 0), rotation.at<double>(2, 1), rotation.at<double>(2, 2), z,
    0.0, 0.0, 0.0, 1.0
  );

  return matrix;
}

int main() {
  // 定义参数
  double x = 111.0;
  double y = 222.0;
  double z = 333.0;
  double rx = 60.0;
  double ry = 30.0;
  double rz = -90.0;

  // 计算 4x4 矩阵
  Mat matrix = xyzEulerToMatrix(x, y, z, rx, ry, rz);

  // 打印结果
  cout << "4x4 矩阵:" << endl << matrix << endl;

  return 0;
}
相关推荐
JAMES费1 分钟前
figure机器人技术架构的演进初探——Helix人形机器人控制的革新
架构·机器人
余~~1853816280034 分钟前
矩阵碰一碰发视频的后端源码技术,支持OEM
线性代数·矩阵·音视频
阿巴~阿巴~35 分钟前
多源 BFS 算法详解:从原理到实现,高效解决多源最短路问题
开发语言·数据结构·c++·算法·宽度优先
CoderCodingNo1 小时前
【GESP】C++二级真题 luogu-b3924, [GESP202312 二级] 小杨的H字矩阵
java·c++·矩阵
@ V:ZwaitY091 小时前
如何打造TikTok矩阵:多账号管理与内容引流的高效策略
人工智能·矩阵·tiktok
_Itachi__1 小时前
LeetCode 热题 100 73. 矩阵置零
算法·leetcode·矩阵
刃神太酷啦2 小时前
堆和priority_queue
数据结构·c++·蓝桥杯c++组
Heris992 小时前
2.22 c++练习【operator运算符重载、封装消息队列、封装信号灯集】
开发语言·c++
----云烟----2 小时前
C/C++ 中 volatile 关键字详解
c语言·开发语言·c++
01_3 小时前
力扣hot100 ——搜索二维矩阵 || m+n复杂度优化解法
算法·leetcode·矩阵