SLAM 基础学习记录(1) 载体速度解算载体位姿 ECEF解算ENU坐标系位置

本文记录了SLAM学习过程中的载体速度解算及其在ECEF到ENU坐标系转换中的应用。通过姿态角分解载体速度,转换坐标系,然后进行时间积分解算位姿。在实际解算中发现,未经正确坐标转换的载体速度积分与ECEF解算的ENU位姿不一致,经过修正,解决了初始异常点和转弯误差导致的定位偏差问题。目前,Z轴上的偏移问题尚未解决,未来需要进一步完善。
摘要由CSDN通过智能技术生成

载体速度解算载体位姿

载体速度对时间进行积分,传感器为NAV982惯性导航,其坐标系:X轴向右,Y轴向前,Z轴向下,符合右手坐标系原则。

在对载体速度进行时间积分前

1. 一定要用姿态角进行在各个方向的载体速度分解

2. 要将载体坐标系转换到世界坐标系下。(以载体初始位置为原点,东北天(ENU)坐标系的定义方式为世界坐标系)

相关代码如下:

  MatrixXf Z_RotMat(3,3);
  MatrixXf Y_RotMat(3,3);
  MatrixXf X_RotMat(3,3);
  MatrixXf CurrentVelocit(3,1);
  MatrixXf TransformToENU(3,3);

  TransformToENU << 0, 1, 0, 1, 0, 0, 0, 0, -1;  //载体坐标系转换到ENU坐标系
  Z_RotMat<< cos(yaw),  -sin(yaw),  0,  sin(yaw),  cos(yaw),  0,  0,  0,  1;
  Y_RotMat<< cos(pitch),   0,  sin(pitch),  0,  1,  0,  -sin(pitch), cos(pitch),  0;
  X_RotMat<< 1,  0,   0,  0,  cos(roll),  -sin(roll),  0,  sin(roll),  cos(roll);

  CurrentVelocit<< imuIn->BodyVelocity_[0], imuIn->BodyVelocity_[1], imuIn->BodyVelocity_[2];
  CurrentVelocit = TransformToENU * X_RotMat * Y_RotMat * Z_RotMat * CurrentVelocit;

ECEF解算位姿

利用前面关于几个坐标系的转换方法,将获取到的ECEF数据解算为ENU坐标系位姿。

①输入:

经度:Lon;纬度:Lat;第一组接受到的ECEF数据:x0,y0,z0;后面接收到的ECEF数据:x,y,z。

②计算:

ee = [-sin(Lon),cos(lon),0];

en = [-cos(Lon)*sin(Lat),-sin(Lon)*sin(L

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值