hp-da-pt19


Namehp-da-pt19 JSON
Version 0.0.2 PyPI version JSON
download
home_pagehttps://github.com/da-vidi21/HP_DA_PT19
SummaryPackage contaning python wrapper for supporting pitch,roll,yaw, swarms, and more
upload_time2023-02-02 18:31:24
maintainer
docs_urlNone
authorAnonymous
requires_python>=3.6
licenseMIT
keywords drone sdk python
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Drona Aviation Pluto Drone Swarm Challenge

- Click here to read the problem statement [High_Drona.pdf](High_Drona.pdf)
- Click here to read the report[Report_Task_1&2.pdf]()


 Python wrapper for intraction with official Pluto Drone's firmware API. This package has following features:

**Task-1**

- [x] Implementation of control commands for the drone movements.(such as Pitch forward, Roll
left, take off - Land, etc.)

**Task-2**

- [x] Overhead camera calibration method
- [x] ArUCo tag detection and tracking
- [x] Pose estimation of the ArUCo tag
- [x] Implementation of PID for controlling drone
- [x] Drone Hovering
- [x] Drone movement in a rectangle of (1x2 meter)

**Task-3**

- [ ] Drone Swarming in a rectangle of(1x2 meter)  

## Installation Using pip
```
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
```

## Installation in Developer Mode
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 .
```
## Approach 
![approach](Images/Flowchart.png)
## File Description
- **[calibration.py](hp_da_pt19/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` and `distortion_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](hp_da_pt19/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](hp_da_pt19/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 the `Drone` 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` and `set_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.

- **[pidaxischanged.py](hp_da_pt19/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.

- **[rectangle.py](hp_da_pt19/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).

    ```
    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.

- **[utils.py](hp_da_pt19/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.

## References

- https://in.mathworks.com/discovery/pid-control.html

## Citations
```
@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}
}
```


            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/da-vidi21/HP_DA_PT19",
    "name": "hp-da-pt19",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.6",
    "maintainer_email": "",
    "keywords": "drone,sdk,python",
    "author": "Anonymous",
    "author_email": "vidit21srivastava@gmail.com",
    "download_url": "",
    "platform": null,
    "description": "# Drona Aviation Pluto Drone Swarm Challenge\n\n- Click here to read the problem statement [High_Drona.pdf](High_Drona.pdf)\n- Click here to read the report[Report_Task_1&2.pdf]()\n\n\n Python wrapper for intraction with official Pluto Drone's firmware API. This package has following features:\n\n**Task-1**\n\n- [x] Implementation of control commands for the drone movements.(such as Pitch forward, Roll\nleft, take off - Land, etc.)\n\n**Task-2**\n\n- [x] Overhead camera calibration method\n- [x] ArUCo tag detection and tracking\n- [x] Pose estimation of the ArUCo tag\n- [x] Implementation of PID for controlling drone\n- [x] Drone Hovering\n- [x] Drone movement in a rectangle of (1x2 meter)\n\n**Task-3**\n\n- [ ] Drone Swarming in a rectangle of(1x2 meter)  \n\n## Installation Using pip\n```\npip install hp-da-pt19\n```\nFor Linux distributions with both python2 and python3 (e.g. Debian, Ubuntu, ...) you need to run\n\n```\npip3 install hp-da-pt19\n```\n\n## Installation in Developer Mode\nUsing the commands below you can install the repository in developer mode. This allows you to modify the library and use the modified version regularly.\n\n```\ngit clone https://github.com/da-vidi21/HP_DA_PT19.git\ncd HP_DA_PT19\npip install -e .\n```\n## Approach \n![approach](Images/Flowchart.png)\n## File Description\n- **[calibration.py](hp_da_pt19/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` and `distortion_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.\n\n    ```\n    def calibrate(cam_src, frame_count, square_size, width, height, visualize=False):\n    ```\n    - Determines the camera matrix and the distortion coefficients from the image points.\n\n\n\n- **[arucoTracking.py](hp_da_pt19/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.\nIn our case we have used 4X4 ArUCo tag Dictionary.\n\n\n    ```\n    def start(self): \n    ```\n    - Initiates the tracking thread.\n\n\n    ```\n    def read_position(self, id): \n    ```\n    - Tracks the latest position of drone with given specific id and returns empty array if not detected.\n\n    ```\n    def read_smooth_position(self, id):\n    ```\n    - Returns the position of drone after applying smoothing.\n\n    ```\n    def read_z_rotation(self, id):\n    ```\n    - Returns the z rotation of the tag.\n\n    ```\n    def stop(self): \n    ```\n    - Terminates the tracking thread\n\n    ```\n    def set_origin(self, origin):  \n    ```\n    - Sets the given passed coordinate as the orgin of the coordinate system.\n\n    ```\n    def update(self): \n    ```\n    - For updating the position of the drone with the tracking data freceived from the latest frame.\n\n    ```\n    def generate_smooth_position(self, id):\n    ```\n    - For calculating the smoothed position of the drone.\n\n    ```\n    def moving_average(self, position_store):\n    ```\n    - Applies moving average to smooth out the coordinate values.\n\n    ```\n    def median_smoothing(self, position_store):\n    ```\n    - Applies median smoothing to smooth out the coordinate values.\n\n    ```\n    def get_velocity(self, id=0):\n    ```\n    - Returns the velocity of drone.\n\n\n- **[Communication.py](hp_da_pt19/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.\n\n    ```\n    def __init__(self, IP_ADDRESS, PORT, id, debug=False):\n    ```\n    - Initializes the `Drone` object and sets base properties and values for it whenever the `Drone` object is created.\n\n    ```\n    def connect(self):\n    ```\n    - Starts the thread for `__com_thread `function.\n\n    ```\n    def disconnect(self):\n    ```\n    - Terminates the socket connection with the drone.\n\n    ```\n    def __com_thread(self):\n    ```\n    - Tries to establish a connection with the drone and launch the `__update()` function.\n\n    ```\n    def __update(self): \n    ```\n    - Every 22nd millisecond delivers the most recent values of `rc_raw_data` and `set_cmd_data` to the drone.\n\n    ```\n    def __update_checksum(self):\n    ```\n    - Updates the checksum.\n\n    ```\n    def __get_LSB_MSB(self, val):\n    ```\n    - Returns the LSB and MSB values of the given input in range from 900(min) to 2100(max).\n\n    ```\n    def __set_rc_raw(self):\n    ```\n    - Sends the raw RC values like throttle, pitch, roll,etc to the drone.\n\n    ```\n    def set_cmd(self):\n    ```\n    - Sends commands to the drone for Take-off and Landing.\n\n    ```\n    def arm(self):\n    ```\n    - Modifies `rc_raw_data` in order to arm the drone.\n\n    ```\n    def disarm(self):\n    ```\n    - Modifies `rc_raw_data` in order to disarm the drone.\n\n    ```\n    def takeoff(self):\n    ```\n    - Modifies `rc_raw_data` in order to Take-off the drone.\n\n    ```\n    def land(self):\n    ```\n    -  Modifies `rc_raw_data` in order to land the drone.\n\n    ```\n    def set_throttle(self, val): \n    ```\n    - Modifies `rc_raw_data` in order to change the throttle of the drone as per the input.\n\n    ```\n    def set_pitch(self, val): \n    ```\n    - Modifies `rc_raw_data` in order to change the pitch of the drone as per the input.\n\n    ```\n    def set_roll(self, val): \n    ```\n    - Modifies `rc_raw_data` in order to change the roll of the drone as per the input.\n\n    ```\n    def set_yaw(self, val):\n    ```\n    - Modifies `rc_raw_data` in order to change the yaw of the drone as per the input.\n\n    ```\n    def set_state(self, throttle, pitch, roll, yaw=1500):\n    ```\n    - Modifies the state values of the drone as per input and further modifies the `rc_raw_data` accordingly.\n\n- **[pidaxischanged.py](hp_da_pt19/pidaxischanged.py)** :This file contains code for calculating the state values of the drone and clamping the state values according to the PID controller.\n\n    ```\n    def __init__(self, target_position, k_values, range):\n    ```\n    - Initialises the values and properties of the PID controller.\n        - Coordinates of the target position are relative to the origin position.\n        - Axis of the camera module is inverted with that of the drone axis.\n\n    ```\n    def calculate_state(self, current_position):\n    ```\n    - For calculating the state values as per the drone's `current_position`.\n\n    ```\n    def set_target(self, checkpoint):\n    ```\n    - Defines the target positon to the passed checkpoint.\n        - Checkpoint is a list of form *[x,y,z]*.\n\n\n    ```\n    def get_error(self): \n    ```\n    - Returns the current state error.\n\n    ```\n    def clamp_state_values(self):\n    ```\n    - Clamps the state values according to the input received in the range during initiation.\n\n- **[rectangle.py](hp_da_pt19/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).\n\n    ```\n    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):\n    ```\n    - For the drone movement to the specific checkpoint.\n        - Checkpoint format consists of *[x,y,z]* and the time alloted for it.\n        - Further permissible error values in x,y,z and rms velocity has been provided.\n        - `id=0` is the ID number of the associated ArUCo tag.\n\n- **[utils.py](hp_da_pt19/utils.py)** : This file contains the code required for various utilities required for the functionalities.\n\n    ```\n    def aruco_display(corners, ids, rejected, image):\n    ```\n    - Computes and draws the center *$[x, y]$* coordinates of the ArUco\n\n    ```\n    def show_fps(output): \n    ```\n    - Returns the frame rate in the tracking display.\n    ```\n    def print_coordinates(tvec): \n    ```\n    - Returns the tracking coordinate.\n    ```\n    def plot(commands, coords, flight_duration, y=\"pitch\", all=False):\n    ```\n    - Plots the tracking data(given by `pos_tracker`) and state values(given by PID controller).\n    ```\n    def plot_velo(velo_arr, flight_duration): \n    ```\n    - Plots the velocity of the drone against time.\n\n## References\n\n- https://in.mathworks.com/discovery/pid-control.html\n\n## Citations\n```\n@article{article,\nauthor = {Wibowo, Agung and Susanto, Erwin},\nyear = {2018},\nmonth = {09},\npages = {81},\ntitle = {Performance Improvement of Water Temperature Control using Anti-windup Proportional Integral Derivative},\njournal = {Lontar Komputer : Jurnal Ilmiah Teknologi Informasi},\ndoi = {10.24843/LKJITI.2018.v09.i02.p03}\n}\n```\n\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Package contaning python wrapper for supporting pitch,roll,yaw, swarms, and more",
    "version": "0.0.2",
    "split_keywords": [
        "drone",
        "sdk",
        "python"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "d9b12d9f29f4e400c92e638956192cefae637240e1fd6120576e43c48c10d302",
                "md5": "45638103dc119f625693b38264faf66d",
                "sha256": "3d5caa1293a7830c8d17afd55bfad982a68a843b71b17a708fb63146cf7b8090"
            },
            "downloads": -1,
            "filename": "hp_da_pt19-0.0.2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "45638103dc119f625693b38264faf66d",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.6",
            "size": 16908,
            "upload_time": "2023-02-02T18:31:24",
            "upload_time_iso_8601": "2023-02-02T18:31:24.733002Z",
            "url": "https://files.pythonhosted.org/packages/d9/b1/2d9f29f4e400c92e638956192cefae637240e1fd6120576e43c48c10d302/hp_da_pt19-0.0.2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-02-02 18:31:24",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "github_user": "da-vidi21",
    "github_project": "HP_DA_PT19",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [],
    "lcname": "hp-da-pt19"
}
        
Elapsed time: 0.05532s