Skip to content

Latest commit

 

History

History
138 lines (109 loc) · 7.18 KB

README.md

File metadata and controls

138 lines (109 loc) · 7.18 KB

FLYING AR-DRONE USING TAGS

ABOUT

The goal of this project is to have an AR-Drone fly and obtain instructions from markers (aka tags) on the wall in order to direct it. The code is built in such a way that the movement is not hard coded, but the instruction of each tag is - thus you can change the placements of the tags on the walls and without changing the code the drone should change its movement accordingly.

In order to obtain this goal we use ROS Kinetic in addition to some open-source github repositories. Tested on Ubuntu 16.04.

NOTE: The main package with my code is drone_application. Other packages included here are packages which I used and may have edited slightly, thus it may be easier to just copy them from here rather than copy the original repositories and try to edit them to what I have.

Preperation Instructions

  • It is recommended to go through the ROS tutorials and install ROS Kinetic through them: http://wiki.ros.org/ROS/Tutorials/

  • After installing ROS Kinetic:

    • Put the directory drone_application in ~/catkin_ws/src.

    • The following repositories need to be downloaded and installed:
      https://github.com/AutonomyLab/ardrone_autonomy
      https://github.com/sniekum/ar_track_alvar

      • ardrone_autonomy wiki: https://ardrone-autonomy.readthedocs.io/en/latest/
      • ardrone_autonomy installation instructions:
        The official installation instructions do not mention kinetic, but an installation is available in the Ubuntu repos:
        sudo apt-get install ros-kinetic-ardrone-autonomy
      • ar_track_alvar wiki:
        http://wiki.ros.org/ar_track_alvar
      • ar_track_alvar installation instructions:
        The official installation instructions do not mention kinetic, but an installation is available in the Ubuntu repos:
        sudo apt-get install ros-kinetic-ar-track-alvar
    • tum simulator and gazeebo - optional:
      gazeebo - http://gazebosim.org/tutorials?tut=install_ubuntu&cat=install
      tum simulator - https://github.com/angelsantamaria/tum_simulator

      • gazeebo installation:
        We install gazeebo 7 as the hector quad-copter requires that version.
        sudo apt-get install libsdformat4
        sudo apt-get install gazebo
        You may also need to upgrade after this in order to have gazebo working (I don't know why, but I had to):
        sudo apt-get upgrade
      • tum simulator and wiki (ignore installation instructions in wiki):
        http://wiki.ros.org/tum_simulator
      • tum simulator installation instructions:
        • Dependencies:
          *Hector quadrotor: As an example you can install all hector suite running
          sudo apt-get install ros-<your_version>-hector-*
          • Pre-mentioned ardrone autonomy
        • I added some tags to my gazeebo worlds within tum simulator, as such I recommend copying my tum_simulator folder into ~/catkin_ws/src instead of downloading the folder from the github repository.
        • In order for the markers to appear in the worlds I created you will need to download the following repository:
          https://github.com/mikaelarguedas/gazebo_models
          and install it using the following command from inside the folder "gazebo_models/ar_tags/scripts":
          python generate_markers_model.py -i <path_to_repo_directory>/gazebo_models/images/ -g ~/.gazebo/models -s 20
          NOTE: For details look at the README.md of the gazebo_models repository.
        • You can use the models supplied in the gazeebo_models repository to make new gazeebo worlds of your own.
  • At this point you should compile catkin:
    catkin_make

Running Instructions

  • Real Drone:

    • Connecting to drone:
      roslaunch drone_application launch_drone.launch
    • Starting ar_track_alvar:
      roslaunch drone_application pr2_indiv_no_kinect_edited.launch
    • View drone camera output in real time:
      rosrun image_view image_view image:=/ardrone/front/image_raw
    • Run code and create log file:
      rosrun drone_application real_drone_flight.py | tee ~/catkin_ws/src/drone_application/logs/real_drone_flight_$(date +%Y%m%d%H%M%S).log
    • NOTE: In order to debug effectivly I found it useful to have a screen capture program (like "Simple Screen Recorder") capture the screen with the code running aswell as the drone camera image.
    • Kill switch in case something goes wrong:
      rostopic pub -1 /ardrone/land std_msgs/Empty
    • You might also need to reset and recallibrate your drone after a flight. This can be done by running when the drone is on a flat surface:
      rosservice call /ardrone/flattrim
      rostopic pub -1 /ardrone/reset std_msgs/Empty
  • Gazeebo Simulator:

    • Run simulator:
      roslaunch drone_application test_simulator_tags.launch
    • View drone camera output in real time:
      rosrun image_view image_view image:=/ardrone/front/image_raw
    • Starting ar_track_alvar:
      roslaunch drone_application pr2_indiv_no_kinect_edited.launch
    • Run code and create log file:
      rosrun drone_application simulator_drone_flight.py | tee ~/catkin_ws/src/drone_application/logs/simulator_drone_flight_$(date +%Y%m%d%H%M%S).log

Editing code and testing

  • You can use markerTester2.py to be able to pick up the drone and point at the tags and see the values that ar_track_alvar gives you while the drone captures the tags in different positions. To run markerTester2.py use:
    rosrun drone_application markerTester.py

  • It was convenient for me to do this while haveing the drone camera output viewed on my pc and using a screen capturing tool to see the output of markerTester2.py side by side with what the camera sees

Known Bugs

  • When running using the simulator there is a problem detecting the second tag while directly in front of it. The tag will be detected when it is on the edges of the screen and will center, but once centered it will not detect it and thus infinitly try go back and forth and try centereing.

  • Differences between simulator and real drone code:

    • drone lost time

Useful Sources

Videos of it running

Drone perspective alongside code running:
https://www.youtube.com/watch?v=PMgIAw5WZq8&index=1&list=PL2RVYZOGYIsGPELqET1A5bkZApC9eahHd

3rd person view:
https://www.youtube.com/watch?v=pFPWGxRW1jI&list=PL2RVYZOGYIsGPELqET1A5bkZApC9eahHd&index=2

Playlist:
https://www.youtube.com/watch?v=PMgIAw5WZq8&list=PL2RVYZOGYIsGPELqET1A5bkZApC9eahHd

Licenses

This Project is released under GPL v.3 which can be found in the license file.

Different reposetories used in this project have different open-source licenses and should be checked in the repositories themselves. As of writing this readme file the following licenses apply:

  • tum simulator: "We release our code under the BSD license. However, as we strongly build upon Gazebo and HectorSLAM, corresponding licenses apply as well. "

  • gazebo_models: Apache License

  • ar_track_alvar: LGPL-2.1

  • ardrone_autonomy: BSD License

Credits

Developed originally for the University of the Witwatersrand, South Africa Made by Or Hanoch
Project Manager: Shunmuga Pillay
Professional Adviser: Pravesh Ranchod