Skip to content

Commit

Permalink
fix: convert old autoware_auto_perception_msgs in rosbag to new autow…
Browse files Browse the repository at this point in the history
…are_perception_msgs; feat: new reception_reproducer.
  • Loading branch information
xtk8532704 committed Jun 7, 2024
1 parent 1e93f51 commit 53ad0e6
Show file tree
Hide file tree
Showing 5 changed files with 48 additions and 49 deletions.
1 change: 1 addition & 0 deletions planning/planning_debug_tools/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ install(PROGRAMS
scripts/trajectory_visualizer.py
scripts/closest_velocity_checker.py
scripts/perception_replayer/perception_reproducer.py
scripts/perception_replayer/perception_reproducer_v2.py
scripts/perception_replayer/perception_replayer.py
scripts/update_logger_level.sh
DESTINATION lib/${PROJECT_NAME}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -97,22 +97,13 @@ def on_timer(self):
self.objects_pub.publish(objects_msg)

# traffic signals
# temporary support old auto msgs
if traffic_signals_msg:
if self.is_auto_traffic_signals:
traffic_signals_msg.header.stamp = timestamp
self.auto_traffic_signals_pub.publish(traffic_signals_msg)
else:
traffic_signals_msg.stamp = timestamp
self.traffic_signals_pub.publish(traffic_signals_msg)
traffic_signals_msg.stamp = timestamp
self.traffic_signals_pub.publish(traffic_signals_msg)
self.prev_traffic_signals_msg = traffic_signals_msg
elif self.prev_traffic_signals_msg:
if self.is_auto_traffic_signals:
self.prev_traffic_signals_msg.header.stamp = timestamp
self.auto_traffic_signals_pub.publish(self.prev_traffic_signals_msg)
else:
self.prev_traffic_signals_msg.stamp = timestamp
self.traffic_signals_pub.publish(self.prev_traffic_signals_msg)
self.prev_traffic_signals_msg.stamp = timestamp
self.traffic_signals_pub.publish(self.prev_traffic_signals_msg)

def onPushed(self, event):
if self.widget.button.isChecked():
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,9 @@
from subprocess import check_output
import time

from autoware_perception_msgs.msg import DetectedObjects
from autoware_perception_msgs.msg import PredictedObjects
from autoware_perception_msgs.msg import TrackedObjects
from autoware_perception_msgs.msg import TrafficLightGroupArray
from autoware_perception_msgs.msg import DetectedObjects, PredictedObjects, TrackedObjects
from autoware_perception_msgs.msg import TrafficLightGroupArray, TrafficLightGroup, TrafficLightElement

from geometry_msgs.msg import PoseStamped
from geometry_msgs.msg import PoseWithCovarianceStamped
from nav_msgs.msg import Odometry
Expand Down Expand Up @@ -79,6 +78,10 @@ def __init__(self, args, name):
PoseStamped, "/planning/mission_planning/goal", 1
)

self.traffic_signals_pub = self.create_publisher(
TrafficLightGroupArray, "/perception/traffic_light_recognition/traffic_signals", 1
)

# load rosbag
print("Stared loading rosbag")
if os.path.isdir(args.bag):
Expand All @@ -89,10 +92,6 @@ def __init__(self, args, name):
self.load_rosbag(args.bag)
print("Ended loading rosbag")

self.traffic_signals_pub = self.create_publisher(
TrafficLightGroupArray, "/perception/traffic_light_recognition/traffic_signals", 1
)

# wait for ready to publish/subscribe
time.sleep(1.0)

Expand Down Expand Up @@ -123,10 +122,35 @@ def load_rosbag(self, rosbag2_path: str):
msg_type = get_message(type_map[topic])
msg = deserialize_message(data, msg_type)
if topic == objects_topic:
if not isinstance(msg, self.objects_pub.msg_type):
# convert old autoware_auto_perception_msgs to new autoware_perception_msgs
new_msg = self.objects_pub.msg_type()
for field in msg.__slots__:
setattr(new_msg, field, getattr(msg, field))# it's unsafe because the elements inside the message are still the old type, but it works for now on.
msg = new_msg
self.rosbag_objects_data.append((stamp, msg))

if topic == ego_odom_topic:
self.rosbag_ego_odom_data.append((stamp, msg))

if topic == traffic_signals_topic:
if not isinstance(msg, self.traffic_signals_pub.msg_type):
# convert old TrafficSignalArray msg to new TrafficLightGroupArray msg.
new_msg = self.traffic_signals_pub.msg_type()
new_msg.stamp = msg.stamp
for traffc_signal in msg.signals:

Check warning on line 141 in planning/planning_debug_tools/scripts/perception_replayer/perception_replayer_common.py

View workflow job for this annotation

GitHub Actions / spell-check-partial

Unknown word (traffc)
traffic_lignt_group = TrafficLightGroup()

Check warning on line 142 in planning/planning_debug_tools/scripts/perception_replayer/perception_replayer_common.py

View workflow job for this annotation

GitHub Actions / spell-check-partial

Unknown word (lignt)
traffic_lignt_group.traffic_light_group_id = traffc_signal.traffic_signal_id

Check warning on line 143 in planning/planning_debug_tools/scripts/perception_replayer/perception_replayer_common.py

View workflow job for this annotation

GitHub Actions / spell-check-partial

Unknown word (lignt)

Check warning on line 143 in planning/planning_debug_tools/scripts/perception_replayer/perception_replayer_common.py

View workflow job for this annotation

GitHub Actions / spell-check-partial

Unknown word (traffc)
for traffic_signal_element in traffc_signal.elements:

Check warning on line 144 in planning/planning_debug_tools/scripts/perception_replayer/perception_replayer_common.py

View workflow job for this annotation

GitHub Actions / spell-check-partial

Unknown word (traffc)
traffic_light_element = TrafficLightElement()
traffic_light_element.color = traffic_signal_element.color
traffic_light_element.shape = traffic_signal_element.shape
traffic_light_element.status = traffic_signal_element.status
traffic_light_element.confidence = traffic_signal_element.confidence
traffic_lignt_group.elements.append(traffic_light_element)

Check warning on line 150 in planning/planning_debug_tools/scripts/perception_replayer/perception_replayer_common.py

View workflow job for this annotation

GitHub Actions / spell-check-partial

Unknown word (lignt)
new_msg.traffic_light_groups.append(traffic_lignt_group)

Check warning on line 151 in planning/planning_debug_tools/scripts/perception_replayer/perception_replayer_common.py

View workflow job for this annotation

GitHub Actions / spell-check-partial

Unknown word (lignt)
msg = new_msg

self.rosbag_traffic_signals_data.append((stamp, msg))

def kill_online_perception_node(self):
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -106,22 +106,13 @@ def on_timer(self):
self.recorded_ego_pub.publish(ego_odom[1])

# traffic signals
# temporary support old auto msgs
if traffic_signals_msg:
if self.is_auto_traffic_signals:
traffic_signals_msg.header.stamp = timestamp
self.auto_traffic_signals_pub.publish(traffic_signals_msg)
else:
traffic_signals_msg.stamp = timestamp
self.traffic_signals_pub.publish(traffic_signals_msg)
traffic_signals_msg.stamp = timestamp
self.traffic_signals_pub.publish(traffic_signals_msg)
self.prev_traffic_signals_msg = traffic_signals_msg
elif self.prev_traffic_signals_msg:
if self.is_auto_traffic_signals:
self.prev_traffic_signals_msg.header.stamp = timestamp
self.auto_traffic_signals_pub.publish(self.prev_traffic_signals_msg)
else:
self.prev_traffic_signals_msg.stamp = timestamp
self.traffic_signals_pub.publish(self.prev_traffic_signals_msg)
self.prev_traffic_signals_msg.stamp = timestamp
self.traffic_signals_pub.publish(self.prev_traffic_signals_msg)
self.stopwatch.toc("transform and publish")

self.stopwatch.toc("total on_timer")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ def __init__(self, args):
self.preprocess_data()

# start main timer callback
self.timer = self.create_timer(0.1, self.on_timer)
self.timer = self.create_timer(0.05, self.on_timer)

# kill perception process to avoid a conflict of the perception topics
self.timer_check_perception_process = self.create_timer(3.0, self.on_timer_kill_perception)
Expand Down Expand Up @@ -162,20 +162,12 @@ def on_timer(self):

# traffic signals
if traffic_signals_msg:
if self.is_auto_traffic_signals:# temporary support old auto msgs
traffic_signals_msg.header.stamp = timestamp_msg
self.auto_traffic_signals_pub.publish(traffic_signals_msg)
else:
traffic_signals_msg.stamp = timestamp_msg
self.traffic_signals_pub.publish(traffic_signals_msg)

traffic_signals_msg.stamp = timestamp_msg
self.traffic_signals_pub.publish(traffic_signals_msg)
self.prev_traffic_signals_msg = traffic_signals_msg
elif self.prev_traffic_signals_msg:
if self.is_auto_traffic_signals:# temporary support old auto msgs
self.prev_traffic_signals_msg.header.stamp = timestamp_msg
self.auto_traffic_signals_pub.publish(self.prev_traffic_signals_msg)
else:
self.prev_traffic_signals_msg.stamp = timestamp_msg
self.traffic_signals_pub.publish(self.prev_traffic_signals_msg)
self.prev_traffic_signals_msg.stamp = timestamp_msg
self.traffic_signals_pub.publish(self.prev_traffic_signals_msg)
self.stopwatch.toc("transform and publish")

if not repeat_trigger:
Expand Down Expand Up @@ -227,7 +219,7 @@ def find_nearby_ego_odom_indies(self, ego_pose, search_radius: float):
"-r", "--seach-radius", help="the search radius for searching rosbag's ego odom messages around the nearest ego odom pose (default is 1 meters)", type=float, default=1.0
)
parser.add_argument(
"-c", "--reproduce-cooldown", help="The cooldown time for republishing published messages (default is 40.0 seconds)", type=float, default=30.0
"-c", "--reproduce-cooldown", help="The cooldown time for republishing published messages (default is 40.0 seconds)", type=float, default=40.0
)
args = parser.parse_args()

Expand Down

0 comments on commit 53ad0e6

Please sign in to comment.