No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.

sim_cf2 package from sim_cf2 repo

sim_cf2

Package Summary

Tags No category tags.
Version 0.0.0
License GPLv3
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/crazyfliethi/sim_cf2.git
VCS Type git
VCS Version master
Last Updated 2024-03-23
Dev Status UNMAINTAINED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

The sim_cf2 package

Additional Links

No additional links.

Maintainers

  • tommi

Authors

No additional authors.

ROS2 Gazebo Simulation for the Crazyflie

This project is based on the Gazebo Simulation for Crazyflie CRTP sim_cf from https://github.com/wuwushrek/sim_cf

It features

  • Full software-in-the-loop (SITL) Crazyflie firmware implementation utilizing the FreeRTOS Linux Port https://www.freertos.org/FreeRTOS-simulator-for-Linux.html#SimulatorApp
  • Compatibility with the Crazyflie python library (cflib)
  • Integration of the Crazyflie firmware for SITL build process into KBuild
  • Build for ROS2 and Gazebo 11

In contrast to the original sim_cf, hardware-in-the-loop (HITL) is not supported.

Beside this ROS2 package you will need

  • Crazyflie firmware with modifications for SITL https://github.com/CrazyflieTHI/crazyflie-firmware
  • Crazyflie python library with additional simlink driver https://github.com/CrazyflieTHI/crazyflie-lib-python

Installation - Ubuntu 22.04 with ROS2 Humble and Gazebo 11

Tested on an Ubuntu 22.04 LTS machine

Dependencies

Basic dependencies

sudo apt-get install cmake build-essential genromfs ninja-build

Protobuf, eigen3 and google-glog dependencies

sudo apt-get install protobuf-compiler libgoogle-glog-dev libeigen3-dev libxml2-utils

Cyclone DDS

sudo apt install ros-humble-rmw-cyclonedds-cpp

Xacro library

sudo apt install ros-humble-xacro

Additional ROS2 Packages

Clone ROS2 version of mav_comm into your colcon overlay (assuming ~/dev_ws)

cd ~/dev_ws/src

git clone https://github.com/CrazyflieTHI/mav_comm.git

Build the Packages

Move into your colcon overlay (assuming ~/dev_ws) and use colcon build

cd ~/dev_ws

colcon build

Setting Up the Simulation

Running the simulation requires

  • sim_cf2 package built
  • Crazyflie firmware compiled for SITL
  • Crazyflie python library installed containing the simlink driver

Adjust the Launch Script

The number of simulated Crazyflies is determined by the main launch file main.launch.xml in the sim_cf2/launch folder. By default, two Crazyflies are simulated and code for the instantiation of four further Crazyflies is present but commented out. Adjust the launch file to your needs by adding or removing Crazyflies. Initial pose and rotor color is set in the main.launch.xml file.

Run the Simulation

1. Start Gazebo

Open a terminal and source the ROS2 workspace if not done already (assuming the overlay or workspace in ~/dev_ws)

source ~/dev_ws/install/local_setup.bash

Use the ROS2 launch command to start the sim_cf2 simulation

ros2 launch sim_cf2 main.launch.xml

Gazebo will start in paused mode and will try to establish a connection to the software-in-the-loop Crazyflie firmware instances.

gazebo_successfully_spawned_entities

2. Run Crazyflie Firmware SITL Instances

Open a new terminal and move to the scripts/sim_cf2 folder in the Crazyflie firmware repository (assuming ~/repos/crazyflie-firmware)

cd ~/repos/crazyflie-firmware/scripts/sim_cf2

Run the run_cfs.sh script with as many instances of simulated Crazyflies as needed by providing the amount of Crazyflies as argument (e.g. two)

./run_cfs.sh 2

The SITL instances will establish a connection to Gazebo

sitl_connection_established_with_gazebo

Press PLAY in Gazebo

3. Run a Python Script

Start your cflib-based python script with activated simlink driver. Example scripts can be found in the Crazyflie python library https://github.com/CrazyflieTHI/crazyflie-lib-python/tree/master/examples/sim_cf2

Run for example the autonomousSequence.py script

python autonomousSequence.py

gazebo_successfully_spawned_entities

4. Exit Gazebo and SITL

Press Ctrl+C in the terminals running Gazebo and the SITL instances

Processes should get killed and POSIX message queues should get deleted. If POSIX message queues are not deleted due to errors, they eventually may cause issues when starting the simulation again. The queues are located in /dev/mqueue

If problems occur, delete the queues manually

Show queues

ls /dev/mqueue

Delete the queues

sudo rm /dev/mqueue/<sim_cf2_queues>

Experimental Multi-Ranger Deck

An experimental Multi-ranger deck can be used in the simulation. It consists of four Hokuyo range sensors mounted on a rigid platform attached on top of the Crazyflie.

Enable the Multi-ranger Deck

To use the Multi-ranger deck, enable it in the main.launch.xml file for every Crazyflie individually.

<arg name="enable_mr_deck_1" default="true" />
<arg name="mr_deck_visualize_1" default="true" />

By setting mr_deck_visualize_ to true the laser ray will be visualized.

Run Wall Following Example

With the simulated Multi-ranger deck, Bitcraze’s wall following example can be run. Load a world that contains walls, such as lab_aux.world, by specifying the world name in start_gazebo_world.launch.py

def generate_launch_description():
    world_file_name = 'lab_aux.world' # Select world from worlds folder
    package_name = "sim_cf2"
    ...

A slightly modified version of the wall following example script is located in https://github.com/CrazyflieTHI/crazyflie-lib-python/tree/master/examples/sim_cf2

Start the Gazebo Simulation, an instance of the firmware SITL and run the example.

gazebo_successfully_spawned_entities

CHANGELOG
No CHANGELOG found.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

  • launch/main.launch.xml
      • mav_name [default: crazyflie]
      • enable_logging [default: false]
      • enable_parameters [default: false]
      • use_ros_time [default: true]
      • enable_logging_imu [default: false]
      • enable_logging_temperature [default: false]
      • enable_logging_magnetic_field [default: false]
      • enable_logging_pressure [default: false]
      • enable_logging_battery [default: false]
      • enable_logging_packets [default: false]
      • cfPrefix [default: cf]
      • tf_prefix_1 [default: $(var cfPrefix)1]
      • color_prop_front_1 [default: Green]
      • color_prop_back_1 [default: Green]
      • x_1 [default: 0.5]
      • y_1 [default: -0.5]
      • z_1 [default: 0.03]
      • enable_mr_deck_1 [default: true]
      • mr_deck_visualize_1 [default: true]
      • tf_prefix_2 [default: $(var cfPrefix)2]
      • color_prop_front_2 [default: Blue]
      • color_prop_back_2 [default: Blue]
      • x_2 [default: 0.5]
      • y_2 [default: 0.5]
      • z_2 [default: 0.03]
      • enable_mr_deck_2 [default: true]
      • mr_deck_visualize_2 [default: true]
      • robot_file_sub [default: $(var mav_name)_base.xacro]
  • launch/spawn_mav.launch.xml
      • mav_name [default: crazyflie]
      • robot_file [default: crazyflie_base.xacro]
      • namespace [default: cf1]
      • enable_ground_truth [default: false]
      • enable_wind [default: false]
      • color_prop_front [default: Blue]
      • color_prop_back [default: Blue]
      • enable_mr_deck [default: false]
      • mr_deck_visualize [default: false]
      • rotors_description_dir [default: $(find-pkg-share sim_cf2)/models/rotors_description/]

Services

No service files found

Plugins

No plugins found.

Recent questions tagged sim_cf2 at Robotics Stack Exchange

No version for distro noetic. Known supported distros are highlighted in the buttons above.
No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro lunar. Known supported distros are highlighted in the buttons above.
No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.
No version for distro kinetic. Known supported distros are highlighted in the buttons above.
No version for distro melodic. Known supported distros are highlighted in the buttons above.