- 📑 Click here to read the problem statement | High_Drona.pdf
- 📑 Click here to read the report | Final Submission Report19.pdf
- 📘 Click here for Published Python Package | hp_da_pt19
- 📹 Click here for Demonstration Video | HP_DA_PT19.mp4
- 📙 Click here for presentation | HP_DA_PT19.pptx
Drones are being developed for use in various applications like military, medical aid delivery, as an emergency first responder, for surveillance, etc. They have four counter rotating propellers placed on the same airframe. They are controlled by differential adjustment of the angular velocities of the rotors. Drones can move freely in 3D space i.e.; they have 6 degrees of freedom (DOF). But they have only 4 rotors (actuators) to control all 6 DOF. Thus, they are underactuated systems. Independent control of 2 states namely x (forward/backward), y (right/left) translation is lost. These translations are coupled with the Roll & Pitch angles.
Drona Aviation Pluto 1.2 is an open-source programmable nano drone allows users to integrate with external hardware. So, that we can program our drone to add multiple applications. The drone has an onboard microcontroller that helps implement various algorithms to stabilize and fly the drone. Its firmware is a modified version of the popular, open-source flight software, Cleanflight. Our solution to this challenge comprises of various strategies for the control of this drone.
Python wrapper for intraction with official Pluto Drone's firmware API. This package has following features:
Task-1
- Implementation of control commands for the drone movements.(such as Pitch forward, Roll left, take off - Land, etc.)
Task-2
- Overhead camera calibration method
- ArUCo tag detection and tracking
- Pose estimation of the ArUCo tag
- Implementation of PID for controlling drone
- Drone Hovering
- Drone movement in a rectangle of (1x2 meter)
Task-3
- Drone Swarming in a rectangle of(1x2 meter)
pip install hp-da-pt19
For Linux distributions with both python2 and python3 (e.g. Debian, Ubuntu, ...) you need to run
pip3 install hp-da-pt19
Using the commands below you can install the repository in developer mode. This allows you to modify the library and use the modified version regularly.
git clone https://github.com/da-vidi21/HP_DA_PT19.git
cd HP_DA_PT19
pip install -e .
|-calibration_data
|-calibration_matrix.npy
|-distorsion_coefficients.npy
|-__init__.py
|-arucoTracking.py
|-calibration.py
|-Communication.py
|-pidaxischanged.py
|-rectangle.py
|-swarm.py
|-utils.py
-
calibration.py :This file contains the code necessary for calibrating our camera. This step has several pre-requisites. we need to have a folder containing a set of checkerboard images taken using our camera. We have to make sure that these checkerboard images are of different poses and orientation. We need to provide the path to this directory and the size of the square in metres. We can also change the shape of the checkerboard pattern using the parameters given. We also have to make sure this matches with our checkerboard pattern. This code will generate two numpy files
calibration_matrix.npy
anddistortion_coefficients.npy
. These files are required to execute the next step that involves pose estimation. Note that the calibration and distortion numpy files given in this repository camera and its position specific.def calibrate(cam_src, frame_count, square_size, width, height, visualize=False):
- Determines the camera matrix and the distortion coefficients from the image points.
-
arucoTracking.py : This file contains the code that performs pose estimation and tracking after detecting the ArUCo markers. This is done in real-time for each frame obtained from the camera feed. We need to specify the path to the camera calibration matrix and distortion coefficients obtained from the previous step as well as the type for ArUCo marker we want to detect. In our case we have used 4X4 ArUCo tag Dictionary.
def start(self):
- Initiates the tracking thread.
def read_position(self, id):
- Tracks the latest position of drone with given specific id and returns empty array if not detected.
def read_smooth_position(self, id):
- Returns the position of drone after applying smoothing.
def read_z_rotation(self, id):
- Returns the z rotation of the tag.
def stop(self):
- Terminates the tracking thread
def set_origin(self, origin):
- Sets the given passed coordinate as the orgin of the coordinate system.
def update(self):
- For updating the position of the drone with the tracking data freceived from the latest frame.
def generate_smooth_position(self, id):
- For calculating the smoothed position of the drone.
def moving_average(self, position_store):
- Applies moving average to smooth out the coordinate values.
def median_smoothing(self, position_store):
- Applies median smoothing to smooth out the coordinate values.
def get_velocity(self, id=0):
- Returns the velocity of drone.
-
Communication.py : This file conatins the code that defines the drone's communication methods and the functions for controlling the drone movements and it's connection.This is done in real-time in a seperate thread.
def __init__(self, IP_ADDRESS, PORT, id, debug=False):
- Initializes the
Drone
object and sets base properties and values for it whenever theDrone
object is created.
def connect(self):
- Starts the thread for
__com_thread
function.
def disconnect(self):
- Terminates the socket connection with the drone.
def __com_thread(self):
- Tries to establish a connection with the drone and launch the
__update()
function.
def __update(self):
- Every 22nd millisecond delivers the most recent values of
rc_raw_data
andset_cmd_data
to the drone.
def __update_checksum(self):
- Updates the checksum.
def __get_LSB_MSB(self, val):
- Returns the LSB and MSB values of the given input in range from 900(min) to 2100(max).
def __set_rc_raw(self):
- Sends the raw RC values like throttle, pitch, roll,etc to the drone.
def set_cmd(self):
- Sends commands to the drone for Take-off and Landing.
def arm(self):
- Modifies
rc_raw_data
in order to arm the drone.
def disarm(self):
- Modifies
rc_raw_data
in order to disarm the drone.
def takeoff(self):
- Modifies
rc_raw_data
in order to Take-off the drone.
def land(self):
- Modifies
rc_raw_data
in order to land the drone.
def set_throttle(self, val):
- Modifies
rc_raw_data
in order to change the throttle of the drone as per the input.
def set_pitch(self, val):
- Modifies
rc_raw_data
in order to change the pitch of the drone as per the input.
def set_roll(self, val):
- Modifies
rc_raw_data
in order to change the roll of the drone as per the input.
def set_yaw(self, val):
- Modifies
rc_raw_data
in order to change the yaw of the drone as per the input.
def set_state(self, throttle, pitch, roll, yaw=1500):
- Modifies the state values of the drone as per input and further modifies the
rc_raw_data
accordingly.
- Initializes the
-
pidaxischanged.py :This file contains code for calculating the state values of the drone and clamping the state values according to the PID controller.
def __init__(self, target_position, k_values, range):
- Initialises the values and properties of the PID controller.
- Coordinates of the target position are relative to the origin position.
- Axis of the camera module is inverted with that of the drone axis.
def calculate_state(self, current_position):
- For calculating the state values as per the drone's
current_position
.
def set_target(self, checkpoint):
- Defines the target positon to the passed checkpoint.
- Checkpoint is a list of form [x,y,z].
def get_error(self):
- Returns the current state error.
def clamp_state_values(self):
- Clamps the state values according to the input received in the range during initiation.
- Initialises the values and properties of the PID controller.
-
rectangle.py :This file contains the code for the execution of task mentioned in
Task-2
, i.e. to hover the drone to a specific height and to move the drone in the rectangle of (1x2 meter). To run Task-2 connect to drone via Wi-Fi and then run this file.def visit_checkpoints(checkpoints, x_permissible_error=0.07, y_permissible_error=0.07, z_permissible_error=0.05, permissible_rms_velocity=0.05, id=0):
- For the drone movement to the specific checkpoint.
- Checkpoint format consists of [x,y,z] and the time alloted for it.
- Further permissible error values in x,y,z and rms velocity has been provided.
id=0
is the ID number of the associated ArUCo tag.
- For the drone movement to the specific checkpoint.
-
utils.py : This file contains the code required for various utilities required for the functionalities.
def aruco_display(corners, ids, rejected, image):
- Computes and draws the center $[x, y]$ coordinates of the ArUco
def show_fps(output):
- Returns the frame rate in the tracking display.
def print_coordinates(tvec):
- Returns the tracking coordinate.
def plot(commands, coords, flight_duration, y="pitch", all=False):
- Plots the tracking data(given by
pos_tracker
) and state values(given by PID controller).
def plot_velo(velo_arr, flight_duration):
- Plots the velocity of the drone against time.
-
swarm.py : This file conatains the code required for operating the swarm of drones.
def visitCheckpoints(checkpoints,drone,pos_tracker,pid,id):
- For the movement of specific drone to the specific checkpoint.
- Checkpoint format consists of [x,y,z] and the time alloted for it.
id=0
is the ID number of the associated ArUCo tag.
def nSwarm(checkpoints,ID,IPs):
- For initiating a separate thread for the PID of each drone connected to the system.
- Note: The thread for tracking is same for all the drones.
- For the movement of specific drone to the specific checkpoint.
Controller performance during hovering without tuning and smoothing applied.
Controller performance during hovering with tuning and smoothing applied.
Controller performance during hovering in a rectangle with tuning and smoothing applied.
- Vidit Srivastava
- Pratik Kubal
- Indrayudh Ghosh
- Shlok Kumar Shaw
- Aniket Roy
- Bhavya Garg
- Natasha Banerjee
- Arin Dev
- Akash Kumar
- Akshath Choudhary
- https://in.mathworks.com/discovery/pid-control.html
- https://docs.python.org/3/library/socket.html
- http://www.multiwii.com/wiki/index.php?title=Multiwii_Serial_Protocol
@article{article,
author = {Wibowo, Agung and Susanto, Erwin},
year = {2018},
month = {09},
pages = {81},
title = {Performance Improvement of Water Temperature Control using Anti-windup Proportional Integral Derivative},
journal = {Lontar Komputer : Jurnal Ilmiah Teknologi Informasi},
doi = {10.24843/LKJITI.2018.v09.i02.p03}
}