Skip to content

A revised version of rotorS for external forces resilient planner (with physics engine)

Notifications You must be signed in to change notification settings

yuwei-wu/rotors_simulator

 
 

Repository files navigation


RotorS Instructions for Resilient Planner

This is a customized version to use VID-Fusion and External Forces Resilient Planner. The planner in the simulator has been tested on ubuntu 18.04 and ROS Melodic.

0. Noetic installation addition:

sudo apt install ros-noetic-octomap-ros ros-noetic-joy ros-noetic-mavlink ros-noetic-mavros

Issues: gazebosim/gz-sim#2364 Solution:

sudo add-apt-repository ppa:kisak/kisak-mesa
sudo apt update
sudo apt upgrade

Hil interface issue: https://aur.archlinux.org/packages/ros-noetic-rotors-hil-interface

replace with:

git clone git clone https://aur.archlinux.org/ros-noetic-rotors-hil-interface.git

1. Installation Instructions

Our system has been test on Ubuntu 18.04 with ROS Melodic. you can follow the instructions below to Install and initialize ROS Melodic desktop full, additional ROS packages, catkin-tools, and wstool:

$ sudo sh -c 'echo "deb http://packages.ros.org/ros/ubuntu $(lsb_release -sc) main" > /etc/apt/sources.list.d/ros-latest.list'
$ sudo apt-key adv --keyserver 'hkp://keyserver.ubuntu.com:80' --recv-key C1CF6E31E6BADE8868B172B4F42ED6FBAB17C654
$ sudo apt update
$ sudo apt install ros-melodic-desktop-full ros-melodic-joy ros-melodic-octomap-ros ros-melodic-mavlink ros-melodic-mavros
$ sudo apt install python-wstool python-catkin-tools protobuf-compiler libgoogle-glog-dev ros-melodic-control-toolbox
$ sudo pip install python-uinput pygame
$ sudo rosdep init
$ rosdep update
$ echo "source /opt/ros/melodic/setup.bash" >> ~/.bashrc
$ source ~/.bashrc
$ sudo apt install python-rosinstall python-rosinstall-generator build-essential
  1. If you don't have ROS workspace yet you can do so by: (It's better to directly create a new workspace.)
$ mkdir -p ~/catkin_ws/src && cd ~/catkin_ws/
$ catkin init --workspace .
$ cd src && git clone https://github.com/yuwei-wu/rotors_simulator
$ cd rotors_simular
$ wstool init
$ wstool merge rotors_hil.rosinstall
$ wstool update
  1. Build your workspace
$ cd ~/catkin_ws/
$ catkin build

2. Run the costumed environment

We use the drone "hummingbird" with a vi sensor for testing. After following the instructions of RotorS setting, you can directly run:

source devel/setup.bash && roslaunch rotors_gazebo fast_with_vi_sensor.launch

It will also launch a virtual joystick window and you can press keyboard to control the drone. (The joy interface is revised as position control rather than altitude control, which is easier for interface.)

The important topics are:

For planner:

  • subscribers:

    • ground truth odom: /hummingbird/ground_truth/odometry
    • depth camera: /hummingbird/vi_sensor/camera_depth/depth/disparity
  • publishers:

    • traj cmd: /hummingbird/command/trajectory

For VIO:

  • subscribers:
    • imu_topic: /hummingbird/ground_truth/imu
    • image_topic: /hummingbird/vi_sensor/left/image_raw
    • control_topic: /hummingbird/thrust

To get camera parameters:

Camera info: /hummingbird/vi_sensor/camera_depth/camera/camera_info

3. Set Your Camera Parameters

It's flexible to change its focal length and the position on the drone.

  • internal parameters

In rotors_description/urdf/component_snippets.xacro, start with line 626, find a macro vi_sensor_depth_macro and revise its camera_plugin to change focal length and distortion.

Tutorials for more instructions: http://gazebosim.org/tutorials/?tut=ros_depth_camera

  • external parameters

In rotors_description/urdf/mav_with_vi_sensor.gazebo, to revise the origin xyz and rpy.

  <!-- Mount a VI-sensor in front of the Firefly. -->
  <xacro:vi_sensor_macro
    namespace="${namespace}/vi_sensor"
    parent_link="${namespace}/base_link"
    enable_cameras="true"
    enable_depth="true"
    enable_ground_truth="true">
    <origin xyz="0.1 0.0 0.086" rpy="0.0 0.0 0.0" />
  </xacro:vi_sensor_macro>

4. Adjust External Forces

RotorS has two interfaces to add custom wind: the whole wind distribution or wind during time. For convenience, we also add two easier interfaces. You can both use joystick or disturbance manager to add external forces.

  • By using joystick/keyboard: you can press y/u h/j n/m to add an external force in three dimension

  • By disturbance manager: follow the example in disturbance_manager.cpp to add costumed force.

5. Other Notes

Custom the world file

VID-fusion need features to track, so it's better to change the texture in you environment. In fast_quad.world, I add several brick box with different texture, and their model can be found in rotors_gazebo/models

5.1 Drone's Mass

Because we use hummingbird for testing, when vi-sensor is placed in the CoG of the quadrotor, the rotors will appear in the camera image. However if set in front, it will not stable because of the mass of vi-sensor and need to adjust the parameters of position controller.

To easily avoid the issue, we decrease the mass of vi-sensor near zero and calibrate the mass of drone. By testing during drone's hovering, the mass is mass: 0.745319 now. If you directly clone the original verision, you need to revise it in

5.2 Drone's Color

In rotors_description/urdf/hummingbird.xacro to change the color of the rotors and body of quadrotor.

  <!-- Instantiate multirotor_base_macro once -->
  <xacro:multirotor_base_macro
    robot_namespace="${namespace}"
    mass="${mass}"
    body_width="${body_width}"
    body_height="${body_height}"
    use_mesh_file="${use_mesh_file}"
    color="Grey"
    mesh_file="${mesh_file}">
    <xacro:insert_block name="body_inertia" />
  </xacro:multirotor_base_macro>

About RotorS

RotorS is a MAV gazebo simulator. It provides some multirotor models such as the AscTec Hummingbird, the AscTec Pelican, or the AscTec Firefly, but the simulator is not limited for the use with these multicopters.

There are simulated sensors coming with the simulator such as an IMU, a generic odometry sensor, and the VI-Sensor, which can be mounted on the multirotor.

This package also contains some example controllers, basic worlds, a joystick interface, and example launch files.

Below we provide the instructions necessary for getting started. See RotorS' wiki for more instructions and examples (https://github.com/ethz-asl/rotors_simulator/wiki).

If you are using this simulator within the research for your publication, please cite:

@Inbook{Furrer2016,
author="Furrer, Fadri
and Burri, Michael
and Achtelik, Markus
and Siegwart, Roland",
editor="Koubaa, Anis",
chapter="RotorS---A Modular Gazebo MAV Simulator Framework",
title="Robot Operating System (ROS): The Complete Reference (Volume 1)",
year="2016",
publisher="Springer International Publishing",
address="Cham",
pages="595--625",
isbn="978-3-319-26054-9",
doi="10.1007/978-3-319-26054-9_23",
url="http://dx.doi.org/10.1007/978-3-319-26054-9_23"
}

About

A revised version of rotorS for external forces resilient planner (with physics engine)

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 77.3%
  • Python 15.4%
  • CMake 6.9%
  • Other 0.4%