#!/usr/bin/env python import rospy from nav_msgs.msg import Odometry import tf import math def normalize_quaternion(x, y, z, w): norm = math.sqrt(x**2 + y**2 + z**2 + w**2) return x / norm, y / norm, z / norm, w / norm def odom_callback(msg): # Extract position and orientation from the odometry message position = msg.pose.pose.position orientation = msg.pose.pose.orientation # Normalize the quaternion qx, qy, qz, qw = normalize_quaternion( orientation.x, orientation.y, orientation.z, orientation.w ) # Get frame IDs from the message parent_frame_id = msg.header.frame_id if msg.header.frame_id else "odom" child_frame_id = msg.child_frame_id if msg.child_frame_id else "base_link" # Broadcast the transformation br = tf.TransformBroadcaster() br.sendTransform( (position.x, position.y, position.z), # Translation (qx, qy, qz, qw), # Normalized rotation (quaternion) rospy.Time.now(), # Timestamp child_frame_id, # Child frame ID parent_frame_id # Parent frame ID ) def main(): rospy.init_node('odom_tf_publisher', anonymous=True) rospy.Subscriber('/odom', Odometry, odom_callback) rospy.loginfo("TF Publisher for /odom topic is running...") rospy.spin() if __name__ == '__main__': main()