All Projects → fsstudio-team → ZeroSimROSUnity

fsstudio-team / ZeroSimROSUnity

Licence: MIT license
Robotic simulation in Unity with ROS integration.

Programming Languages

C#
18002 projects
ShaderLab
938 projects

Projects that are alternatives of or similar to ZeroSimROSUnity

my ROS mobile robot
Differential drive mobile robot using ROS.
Stars: ✭ 123 (+9.82%)
Mutual labels:  gazebo, mobile-robots
Awesome Robotics
A curated list of awesome links and software libraries that are useful for robots.
Stars: ✭ 478 (+326.79%)
Mutual labels:  sensors, image-segmentation
Onboard Sdk
DJI Onboard SDK Official Repository
Stars: ✭ 669 (+497.32%)
Mutual labels:  lidar, sensors
ign-sensors
Provides numerous sensor models designed to generate realistic data from simulation environments.
Stars: ✭ 30 (-73.21%)
Mutual labels:  gazebo, sensors
conde simulator
Autonomous Driving Simulator for the Portuguese Robotics Open
Stars: ✭ 31 (-72.32%)
Mutual labels:  gazebo, mobile-robots
wpr simulation
No description or website provided.
Stars: ✭ 24 (-78.57%)
Mutual labels:  gazebo, mobile-robots
OpenMaterial
3D model exchange format with physical material properties for virtual development, test and validation of automated driving.
Stars: ✭ 23 (-79.46%)
Mutual labels:  lidar, sensors
Autonomous-Parking-System
Automatic Parking is an autonomous car maneuvering system (part of ADAS) that moves a vehicle from a traffic lane into a parking spot to perform parallel parking. The automatic parking system aims to enhance the comfort and safety of driving in constrained environments where much attention and experience is required to steer the car. The parking…
Stars: ✭ 39 (-65.18%)
Mutual labels:  gazebo
anavi-examples
Examples for getting started and testing ANAVI Internet of Things and add-on boards (HAT & pHAT) for Raspberry Pi
Stars: ✭ 38 (-66.07%)
Mutual labels:  sensors
Deep-One-Shot-Logo-Retrieval
A Deep One-Shot Network for Query-based Logo Retrieval [Pattern Recognition 2019, Elsevier]
Stars: ✭ 58 (-48.21%)
Mutual labels:  image-segmentation
DSP-SLAM
[3DV 2021] DSP-SLAM: Object Oriented SLAM with Deep Shape Priors
Stars: ✭ 377 (+236.61%)
Mutual labels:  lidar
CNN-DICOM-Segmentation
DICOM Image Segmentation with CNNs in Tensorflow
Stars: ✭ 87 (-22.32%)
Mutual labels:  image-segmentation
segRetino
An implementation of the research paper "Retina Blood Vessel Segmentation Using A U-Net Based Convolutional Neural Network"
Stars: ✭ 23 (-79.46%)
Mutual labels:  image-segmentation
dockerfiles
Dockerfiles I use for development
Stars: ✭ 64 (-42.86%)
Mutual labels:  gazebo
lodToolkit
level-of-details toolkit(LTK). Convert osgb lod tree to 3mx tree. Convert pointcloud in ply/las/laz/xyz to 3mx/osgb tree.
Stars: ✭ 81 (-27.68%)
Mutual labels:  lidar
MATBOX Microstructure analysis toolbox
MATBOX is an open-source MATLAB toolbox dedicated to microstructure analsyis of porous/heterogeneous materials
Stars: ✭ 27 (-75.89%)
Mutual labels:  image-segmentation
FlashRL
No description or website provided.
Stars: ✭ 25 (-77.68%)
Mutual labels:  reinforcement-learning-environments
awesome-ros-mobile-robot
😎 A curated list of awesome mobile robots study resources based on ROS (including SLAM, odometry and navigation, manipulation)
Stars: ✭ 284 (+153.57%)
Mutual labels:  mobile-robots
PointCloudSegmentation
The research project based on Semantic KITTTI dataset, 3d Point Cloud Segmentation , Obstacle Detection
Stars: ✭ 62 (-44.64%)
Mutual labels:  lidar
fiap-ml-visao-computacional
Repositório dos exemplos e desafios utilizados na disciplina de Visão Computacional do curso de MBA Machine Learning da FIAP
Stars: ✭ 33 (-70.54%)
Mutual labels:  image-segmentation

ZeroSim

ZeroSim is a robotics simulation engine built on the easy to use Unity 3D development platform and the power of the Robotics Operating System (ROS). ZeroSim is designed for ease of use and rapid development of all sorts of robotics and simulation -- from warehouses and industrial settings, to farming and outdoors -- from robotic arms to ground and drone based mobile robots.

ZeroSim is a project developed over several years by FS Studios for the rapid development of all sorts of robotic simulation projects for various clients, from robotic arms to mobile robots.

We are releasing ZeroSim as open source to support the community of roboticist and software engineers that have supported us over the decades. We are in active development and welcome all feature requests, bug reports, and pull requests.

MoveIt Example Mobile Robot Example

Overview

ZeroSim provides a multitude of tools for building robots and environments in Unity to interface with ROS. We strive to provide the same functionality and ROS interfaces of Gazebo. Including:

  • Dynamics simulation using the latest PhysX 4.x integrated in Unity.

    • Hinge, ball, linear and fixed joints.
  • Advanced 3D Rendering, including the latest realtime ray tracing technology.

  • Sensors:

  • Ready to use ROS standard controllers and plugins:

  • Full ROS messaging communications layers API.

    • Many premade standard ROS messages
    • Subscribe and publish
    • Action Servers
    • Fast and efficient message encoding using ROS Bridge and BSON over TCP.
    • Parameter server
  • Ready to run prebuilt ROS Docker images available publically on DockerHub: https://hub.docker.com/r/zerodog/zerosim_ros_vnc

  • Machine Learning tools:

    • Image Segmentation for training semantic segmentation algorithms.
  • URDF Import & Export

  • ROS2 support via ROS Bridge Suite (https://github.com/RobotWebTools/rosbridge_suite)

  • COMING SOON:

    • Configure and run Docker images within Unity Editor.
    • Secure communications via WebSockets.
    • Drone controller.

API Documentation

API Documentation

Getting Started

Video Tutorials

Tutorial #1: Install ZeroSim in Unity

Tutorial #2: Create a New ZeroSim Unity Scene

Tutorial #3: Connect to ROS

Tutorial #4: Build a Robot From Scratch

Tutorial #5: Import URDF Robot Universal Robots UR10 Arm

https://youtu.be/VJyvjJUfjv8

Recommended System

  • Ubuntu 18.04 or 20.04 (may work on MacOS or Windows but currently untested)
  • Unity 2020.x LTS (IMPORTANT: Currnetly Unity 2021.x breaks a lot of things. We hope to support 2021 in the near future.)
  • Git LFS
  • ROS Melodic (ZeroSim provides a pre-built Docker container for ROS functionality https://hub.docker.com/r/zerodog/zerosim_ros_vnc)
    • Note: ROS Melodic is our primary supported development environment, but ZeroSim has reportedly been able to run on Noetic and ROS2.

Setting up a new Unity Project

  1. In Unity Hub create a new Unity project using Unity 2020.x or later. New Unity Project
  2. Add ZeroSim via Unity Packages:
    1. IMPORTANT: Make sure GIT LFS is installed on your system before continuing!
    2. Unity Menu Window -> Package Manager
    3. Select the + dropdown:
      Dropdown
    4. Select Add Package From Git URL... and enter [email protected]:fsstudio-team/ZeroSimROSUnity.git. Note this can take upto a few minutes to update but you should see the following:
      ZeroSim Package Installed
    5. Import the ZeroSim Samples by selecting the Samples Import button in the Package Manager:
      Import ZeroSim Samples
  3. IMPORTANT the default Unity physics settings do not work well with a lot of simulations. It is very much recommended (required for probably most all simulations) to set the physics settings by opening the Unity menu Edit -> Project Settings... -> Physics and set the Default Solver Iterations to 30 and the Default Solver Velocity Iterations to 60. Unity Physics Settings
  4. IMPORTANT the default Unity fixed timestep setting does not work well with a lot of simulions. It is very much recommended to set the Fixed Timestep setting by Edit -> Project Settings... -> Time to 0.005 Timestep Settings
  5. If running Unity on Linux you want to avoid using OpenGL and use Vulkan, otherwise image based sensors may run slowly or not at all. To change to using Vulkan:
    1. In the Unity Menu: Edit -> Project Settings...:
    2. Uncheck Auto Graphics API for Linux and then under Graphics APIs for Linux set Vulkan ahead of OpenGL:
      Vulkan Settings

Getting ZeroSim ROS Docker Container

  1. Available at https://hub.docker.com/r/zerodog/zerosim_ros_vnc or docker pull zerodog/zerosim_ros_vnc:latest

Running TurtleBot Test Scene

NOTE: Order of operations is important. Especially starting the Docker before the Unity simulation.

  1. Make sure that the ZeroSim samples are installed as outlined above.
  2. Make sure that the ZeroSim Docker container above is installed.
  3. Open the Turtlebot3_Waffle_test.scene Open Turtlebot Scene
  4. Launch the ZeroSim Docker via:
docker run -it --rm \
--publish=9090:9090 \
--publish=11311:11311 \
--publish=8083:8083 \
--publish=80:80 \
--publish=5678:5678 \
--name my_zerosim_vnc_docker \
zerodog/zerosim_ros_vnc:latest \
roslaunch zero_sim_ros basic_unity_editor.launch

  1. Run the ROS teleop in a seperate terminal by running:
docker exec -it my_zerosim_vnc_docker \
bash -c "source devel/setup.bash ; rosrun turtlebot3_teleop turtlebot3_teleop_key"
  1. In the Unity editor press the "Play" button.
  2. The Turtlebot can now be controlled via the w a s d keys in the ROS teleop console window:

Using RViz for Turtlebot

This will show visualizing the 2D LIDAR and ROS TF in RViz. This uses a VNC viewer to the ZeroSim ROS Docker container.

  1. Startup the Turtlebot Test Scene as detailed above.
  2. Open a noVNC connection by:
    1. In a browser open http://localhost:8083/vnc.html
    2. Press the "Connect" button. noVNC Login
  3. In the VNC window press the LEFT mouse button and select "Terminal". noVNC Terminal
  4. In the new terminal run rviz -d ./src/zero_sim_ros/rviz/turtlebot_viewer.rviz. RViz will start up with a 3D view with the LIDAR scanner visibile. RViz Turtlebot Viewer

Running Universal Robot UR10 Arm Test Scene with MoveIt!

NOTE: Order of operations is important. Especially starting the Docker before the Unity simulation.

  1. Make sure that the ZeroSim samples are installed as outlined above.
  2. Make sure that the ZeroSim Docker container above is installed.
  3. Open the UniversalRobot_UR10_test.scene Open UR10 Scene
  4. Launch the ZeroSim Docker via:
docker run -it --rm \
--publish=9090:9090 \
--publish=11311:11311 \
--publish=8083:8083 \
--publish=80:80 \
--publish=5678:5678 \
--name my_zerosim_vnc_docker \
zerodog/zerosim_ros_vnc:latest \
roslaunch zero_sim_ros ur10_moveit.launch
  1. Start the UR10 test Scene by pressing the Play button.
  2. Open a noVNC connection by:
    1. In a browser open http://localhost:8083/vnc.html
    2. Press the "Connect" button. noVNC Login
  3. In the noVNC window RViz will be setup with MoveIt UR10 RViz MoveIt
  4. You can now to standard MoveIt! operations in RViz to control the UR10 arm UR10 MoveIt

Running Image Segmentation Test

  1. Make sure that the ZeroSim samples are installed as outlined above.
  2. Make sure that the ZeroSim Docker container above is installed.
  3. Open the ImageSegmentation_test.scene Open Segmentation Test Scene
  4. Launch the ZeroSim Docker via:
docker run -it --rm \
--publish=9090:9090 \
--publish=11311:11311 \
--publish=8083:8083 \
--publish=80:80 \
--publish=5678:5678 \
--name my_zerosim_vnc_docker \
zerodog/zerosim_ros_vnc:latest \
roslaunch zero_sim_ros basic_unity_editor.launch
  1. Start the Image Segmentation Test Scene by pressing the Play button.
  2. Open a noVNC connection by:
    1. In a browser open http://localhost:8083/vnc.html
    2. Press the "Connect" button. noVNC Login
  3. In the VNC window press the LEFT mouse button and select "Terminal". noVNC Terminal
  4. In the new terminal run rqt_image_view /image/segmentation_image.
  5. Open up a second terminal and run rqt_image_view /image/image_raw RQT Image View Segmentation

Export URDF

  1. Make sure that the ZeroSim samples are installed as outlined above.
  2. Open scene the URDF_test.scene in the ZeroSim samples.
  3. Select SimpleRobotArm in the scene hierarchy.
    Select Simple Robot Arm
  4. Select Export URDF in the root properties view. Export URDF
  5. Select the directory to export to.
  6. An excellent online URDF viewer is available: https://gkjohnson.github.io/urdf-loaders/javascript/example/index.html Just drag and drop the files exported above.

Import URDF

  1. Right click and select ZeroSim --> Import URDF...

LEO Robot Example

  1. Clone the Leo robot: git clone --recursive https://github.com/LeoRover/leo_common.git
  2. Checkout Melodic version. cd leo_common && git checkout melodic.
  3. Startup ZeroSim Docker mounting the LEO directory:

# make sure you are in parent directory for `leo_common`
cd .. 

# run docker
docker run -it --rm \
--publish=9090:9090 \
--publish=11311:11311 \
--publish=8083:8083 \
--publish=80:80 \
--publish=5678:5678 \
--name my_zerosim_vnc_docker \
--volume=$(pwd)/leo_common/:/catkin_ws/src/leo_common/ \
zerodog/zerosim_ros_vnc:latest \
bash
  1. In the Docker command prompt build the catkin workspace:
source devel/setup.bash
catkin build
# Make sure to source ROS again to get the new LEO robot
source devel/setup.bash
  1. In the Docker command prompt Run XAcro on the LEO robot to get the URDF:
rosrun xacro xacro src/leo_common/leo_description/urdf/leo_sim.urdf.xacro > /tmp/leo_sim.urdf
  1. Convert LEO robot meshes to .obj for Unity. In the Docker command prompt:
/zerosim_tools/convert_meshes_to_obj.sh ./src/leo_common/leo_description/models
  1. Copy URDF from Docker to host:
# create a directory and a sub-directory to store the URDF and meshes
mkdir -p my_leo_robot/leo_description

# copy the URDF
docker cp my_zerosim_vnc_docker:/tmp/leo_sim.urdf ./my_leo_robot 
  1. Copy Meshes from Docker to host:
# Note we are preserving the path
docker cp my_zerosim_vnc_docker:/catkin_ws/src/leo_common/leo_description/models ./my_leo_robot/leo_description
  1. Fix the URDF paths to the meshes:
# First fix up the .DAEs to point to the OBJs
sed -i 's#.dae#.obj#g' my_leo_robot/leo_sim.urdf

# The fix up the .STLs to point to the OBJs
sed -i 's#.stl#.obj#g' my_leo_robot/leo_sim.urdf

# Now remove the `package://` because we are using the filesystem
sed -i 's#package://#./#g' my_leo_robot/leo_sim.urdf 

  1. In Unity import URDF by: Right click and select ZeroSim --> Import URDF...
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].