Skip to content

Latest commit

 

History

History
71 lines (48 loc) · 5.4 KB

faq.md

File metadata and controls

71 lines (48 loc) · 5.4 KB

Frequently Asked Questions & Troubleshooting

General Questions

Does the package support ROS 2?

Yes it does! You can get started by following this tutorial.

How does your Unity integration compare to ROS#?

Two of the Unity Robotics repos (URDF Importer and TCP Connector) have been forked from the Siemens ROS# repo.

In the URDF Importer we have added the functionality to instantiate a robot from URDF into a Unity scene with Articulation Body components on their corresponding joints.

Aside from facilitating communication with the TCP Endpoint, the TCP Connector contains an adapted version of the MessageGeneration code from ROS#. However, unlike ROS# our messages are transmitted in ROS's own serialization format, eliminating the JSON encoding/decoding step for some significant performance improvements.

You can find more details about the differences between our implementation and ROS#, along with some of their future plans, in the ROS# project.

How can I install the Unity Packages without starting from a template project?

Refer to the Quick Start instructions on how to import these packages.

ROS-TCP Endpoint/Connector

How does the TCP Endpoint compare to Rosbridge Server?

To put it simply, the TCP Endpoint does not have the extra overhead of having to serialize and deserialize from JSON as its only function is to pass 'ROS serialized' messages between Unity and ROS. That being said the TCP Endpoint is not as general as ROS Bridge and has the strict requirement that all messages be serialized by the TCP Connector code.

Here are some preliminary numbers from a few initial tests done during the discovery stage of this project. We will publish more test results publicly after we go through more rigorous testing but these results should be generally close enough for those curious about performance improvements.

Note: These tests were run on a single machine that was only running ROS and a Unity executable.

  1. Sending 100 (1036x1698) images, one per frame, from Unity to ROS. The time was logged when the message was sent from Unity, before being serialized, and again when the message was received by a ROS Subscriber and deserialized into a message object.

    • ROS# with ROS Bridge Suite on average took about 10 seconds per image. The bridge slowed down dramatically after the first 10 or so messages.
    • TCP Connector with the TCP Endpoint on average took ~0.6 seconds per image.
  2. Only testing the TCP Connector and TCP Endpoint to determine how long it would take to send 1000 912x1698 images, one per frame, we found that it took ~12 seconds for the ROS subscriber to receive and deserialize all messages with only ~10 messages never being received.

  3. Finally a test was done calling a ROS service where the service accepts a small message of a few strings and numerics and returns the same message.

The time was logged when the message was sent from Unity before being serialized, again when the message was received and deserialized by the ROS Service, and one more time when Unity receives and deserializes the service response into the message object.

  • ROS# with ROS Bridge Suite took ~2 seconds
  • TCP Connector with TCP Endpoint took ~0.17 seconds

I'm getting the error: ...failed because unknown error handler name 'rosmsg'.

This is due to a bug in an outdated package version. Try running sudo apt-get update && sudo apt-get upgrade to upgrade.

URDF-Importer

I don't see an option to Import Robot from URDF, or I have compile errors upon importing the URDF-Importer.

The ArticulationBody has dependencies on Unity Editor versions 2020.2.0+. Try updating your project to the latest 2020.2 release.

Can't find what you're looking for?

Connect directly with the Robotics team at unity-robotics@unity3d.com!