#!/usr/bin/env python # -*- coding: utf-8 -*- import time, random, dora from dora import Node import pyarrow as pa context = dora.experimental.ros2_bridge.Ros2Context() node = context.new_node("turtle_teleop", "/ros2_demo", dora.experimental.ros2_bridge.Ros2NodeOptions(rosout=True)) topic_qos = dora.experimental.ros2_bridge.Ros2QosPolicies(reliable=True, max_blocking_time=0.1) turtle_twist_topic = node.create_topic( "/turtle1/cmd_vel", "geometry_msgs::Twist", topic_qos ) twist_writer = node.create_publisher(turtle_twist_topic) turtle_pose_topic = node.create_topic("/turtle1/pose", "turtlesim::Pose", topic_qos) pose_reader = node.create_subscription(turtle_pose_topic) dora_node = Node() dora_node.merge_external_events(pose_reader) print("looping", flush=True) for i in range(500): event = dora_node.next() if event is None: break match event["kind"]: case "dora": match event["type"]: case "INPUT": match event["id"]: case "direction": direction = { "linear": { "x": event["data"][0], }, "angular": { "z": event["data"][5], }, } print(direction, flush=True) twist_writer.publish(pa.array(direction)) case "tick": pass case "external": pose = event.inner()[0].as_py() assert ( pose["x"] != 5.544445 ), "turtle should not be at initial x axis" dora_node.send_output( "turtle_pose", pa.array( [ pose["x"], pose["y"], pose["theta"], pose["linear_velocity"], pose["angular_velocity"], ], type=pa.float64(), ), )