Hi! Thank you for showing interest in our simulator! The full name of the (currently) workshop paper is "HARDNAV - Simulator for Benchmarking Robust Navigation and Place Recognition in Large, Confusing and Highly Dynamic Environments". We hope this simulator can help you quickly test your robust perception and spatial intelligence methods against the varying, often extreme conditions that can occur in the real world before doing costly real world experiments. Any feedback is greatly appreciated! Please send any issues or ideas for improvements to [email protected]
Quick showcase of the simulator:
ROS Dependencies:
- ROS-TCP-Endpoint ROS package - needed on the ROS side to connect to Unity.
Unity packages/assets (not needed if you use the executable, only if you want to edit the project in the Unity Editor, add your own features etc.):
- Robotics Unity package - is complementary to the ROS-TCP-Endpoint ROS node. Installation tutorial under the Unity Setup section here.
- YamlDotNet - needed for using YAML to reconfigure the world, project will not compile without it
- DreamForestTree - contains trees, vegetation and ground textures used in Forest1 and ground texture for ScifiBase1. You might want to add colliders to the trees, as they dont have them by default in the package.
- Yughues Free Metal Materials - very nice materials used for most objects in the simulator, and also for reflective and transparent walls
To use the HARDNAV simulator, there are two options:
- A) You can download one of the executable builds at the bottom of the readme,
- B) Or, to make modifications to the existing worlds, create new ones or add your own features/robots into the worlds, you can download the Unity Hub from https://unity.com/download and open the "navigation_unity_project" folder as a Unity project. This will require importing the assets mentioned in the Dependencies section.
For option A, please skip to section 3 of getting started.
If you haven't already, install Unity Hub, open the navigation_unity_project with it, and download the corresponding version of Unity when prompted. After that, install the Robotics Unity package. it is complementary to the ROS-TCP-Endpoint ROS package and is needed on the side of Unity to make the connect Unity to ROS. The instructions for installing it into Unity can be found here.
When you open navigation_unity_project in the Unity editor, it will contain compilation erros, since some scripts require the YamlDotnet package, which due to licensing issues, cannot be included in this repo and must be downloaded from the Unity Asset Store. Open the project in safe mode or ignore the warning, then add the assets mentioned in the Dependencies section to your Unity account, open the package manager in the Unity editor (the Window->Package Manager tab) and import all the assets into the project. The compilation errors should then disappear and the game should be runnable. Open any world in the Scenes folder and enjoy!
The simulator (either running as executable or run by pressing play in the Unity editor) connects to ROS automatically if there is a ROS TCP Endpoint node running along with the Unity game, and there is an active ROS publisher/subscriber node in Unity. If the icon in the top left corner of the Unity game screen is blue, Unity is connected to ROS. Please, download the ROS TCP Endpoint package, add it to your workspace and build it. You can launch it through endpoint.launch in the ros_tcp_endpoint package or by launching core_nodes.launch in navigation_unity_core package in this repo (which now contains only the endpoint).
To use the scripts provided in the repo and also to enable the ResetWorld.srv ROS service, put your navigation_unity_core and navigation_unity_msgs folders to the src folder of your ROS workspace and build them. If you wish to implement new custom message types, then you need to compile them, source your workspace, and then in Unity Editor, go to Robotics->Generate ROS Messages tab
To play around with changing the world settings, you can run the "session_cycler.py" ROS node for showcasing changes of 4 world states, as shown in the video above, or run "place_recognition_from_motion_trial.py" for an example of how an active place recognition trial could work (you can test it on willing human subjects - tell them to try recognizing which area they are spawned in!). You can use these as examples to design your own experiments for developing and benchmarking robust vision-based spatial intelligence methods :)
Available:
- IMUROSPublisher.cs script for turning any GameObject with a Rigidbody intu an IMU sensor with gaussian noise
- RGBCameraROSPublisher.cs script for turning any camera in Unity into a camera that publishes data into ROS
- ROSSIngleTransformPublisher.cs script for publishing ground-truth pose for debugging and evaluating methods (a transform is published between the robot and its last spawnpoint, and also between the robot and the world coodinate frame origin)
- 2 available robots - ClearPath Robotics "jackal" robot with wheels and built-in velocity controller, and a "generic_space" robot which is fully velocity/force controlled (through Twist messages) and has gravity disabled
- URDF importing of other robots is possible through the URDF-Importer package. Adding new robots this way is only available through the Unity Editor and not on runtime, and needs a small amount of assembly - specifically you have to add the IMU, camera and camera publishing components onto the robot GameObject manually. To control wheeled robots, it's easiest to make the wheels spin freely and adding the VelocityControl component in car mode (you can take inspiration from the Jackal robot).
In progress:
- quadrotor UAV, multi-robot support, depth cameras, ultrasound rangefinder
- Adding a replicable benchmark of robust vision-based navigation, as proposed in the workshop paper - Expected towards the end of December 2023.
- Procedural generation of forest / alien planet environments - Expected December 2023.
- Comparison of state-of-the-art SLAM and visual place recognition algorithms on the simulated extreme conditions - Expected December 2023
The ones in normal text are available through the simulator in some way, the ones in italics are planned:
- There is some issue with post-processing motion blur when doing manual render calls, in which the output ROS image is blurred too much, if the camera component is not active. However, if it is active, Unity seems to also render the camera on its own along with the manual render calls. Therefore, motion blur is now disabled for the ROS image data. Bloom works.
Build 4.0 for Linux can be downloaded here: ROS1/ROS2 or in the Releases section of this repo. On startup, it will load up a "jackal" robot with a monocular camera in the "forest1" scene. To change the scenes, modify the config file "ros_packages/navigation_unity_core/unity_world_config/default.yaml" and then apply it by running "rosrun navigation_unity_core default_world_loader.py". An older build 1.0 can be dowloaded here ROS1. Any feedback is welcome!