From 1b2f1d994986e8c56a0008971973d23444d3e8d6 Mon Sep 17 00:00:00 2001 From: rayvburn Date: Fri, 18 Feb 2022 02:12:47 +0100 Subject: [PATCH] hubero_ros - NavigationRos: odometry twist component expressed in base frame (instead of global reference frame) [#31] --- hubero_ros/src/navigation_ros.cpp | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/hubero_ros/src/navigation_ros.cpp b/hubero_ros/src/navigation_ros.cpp index f8307316..8d99e1ba 100644 --- a/hubero_ros/src/navigation_ros.cpp +++ b/hubero_ros/src/navigation_ros.cpp @@ -222,8 +222,17 @@ void NavigationRos::update(const Pose3& pose, const Vector3& vel_lin, const Vect Pose3 odom_pose = pose - pose_initial_; odometry.pose.pose = ignPoseToMsgPose(odom_pose); setIdealCovariance(odometry.pose.covariance); - // twist - odometry.twist.twist = ignVectorsToMsgTwist(vel_lin, vel_ang); + // twist - velocities expressed in the base frame + // pseudoinversion of matrix in NavigationBase::convertCommandToGlobalCs + ignition::math::Matrix3d r( + cos(pose.Rot().Yaw()), sin(pose.Rot().Yaw()), 0.0, + 0.0, 0.0, 0.0, + 0.0, 0.0, 1.0 + ); + Vector3 vel_lin_base = r * vel_lin; + // assume that Z axis direction matches simulator frame and 'base' frame (typically valid) + Vector3 vel_ang_base(0.0, 0.0, vel_ang.Z()); + odometry.twist.twist = ignVectorsToMsgTwist(vel_lin_base, vel_ang_base); setIdealCovariance(odometry.twist.covariance); pub_odom_.publish(odometry);