Implementation MSD19: Difference between revisions

From Control Systems Technology Group
Jump to navigation Jump to search
S160285 (talk | contribs)
 
(243 intermediate revisions by 6 users not shown)
Line 5: Line 5:
</div>
</div>
__TOC__
__TOC__
After a comprehensive understanding of the problem, it was divided into sub-categories to assess and work efficiently and to have a modular system as a deliverable. Following milestones were set up to keep the project on track and achieve the desired goals step by step.
* Hardware Assembly and manual flight of the drone
* Autonomous Flight of the drone
* Localization of the drone
* Path Planning of the drone
* Setting up of visualization environment
* Perception system for the drone
* Integration of sub-systems
* Testing 


=Getting started with Crazyflie 2.X=
=Getting started with Crazyflie 2.X=
<span style="color:red">
Crazyflie is the mini-drone which we used during this project. The positive aspect of Crazyflie is that a considerable amount of research is available online with guidelines to undergo autonomous flights. Considering the scope of this project and economical viability, Crazyflie was a good choice. Getting started section will cover the following main headings:  
'''Need introduction here.'''
 
</span>
* Manual Flight
 
* Autonomous Flight
 
* Modifications
 
* Troubleshooting
 
A recommendation in the start would be to follow the procedure from manual to autonomous flights. Jumping directly into autonomous flight mode is not advised as it will create a lot of ambiguity and lack of understanding of how the basic system works.  


==Manual Flight==
==Manual Flight==
This section explains in detail on how to setup a Crazyflie 2.X drone starting from hardware assembly to first manual flight. We used Windows to continue with initial setup of the software part for manual flight. However, Linux (Ubuntu 16.04) was preferred for the autonomous flight. Following additional hardware is required to setup first manual flight.
This section explains in details on how to set up a Crazyflie 2.X drone starting from hardware assembly to first manual flight. We used Windows to continue with the initial setup of the software part for manual flight. However, Linux (Ubuntu 16.04) is preferred for the autonomous flight. The following additional hardware is required to set up a manual flight:
* Bitcraze Crazyradio PA USB dongle
* Bitcraze Crazyradio PA USB dongle
* A remote control (PS4 Controller or Any USB Gaming Controller)
* A remote control (PS4 Controller or Any USB Gaming Controller)


This [https://www.bitcraze.io/documentation/tutorials/getting-started-with-crazyflie-2-x/ link] was used to get started with assembly and setting up the initial flight requirements
This [https://www.bitcraze.io/documentation/tutorials/getting-started-with-crazyflie-2-x/ link] was used to get started with assembly and set up the initial flight requirements.


'''NOTE''': It must be noted that the Crazyflie is running on its latest firmware. The steps to flash the Crazyflie with latest firmware are discussed [https://www.bitcraze.io/documentation/tutorials/getting-started-with-crazyflie-2-x/ here].
'''NOTE''': It must be noted that the Crazyflie is running on its latest firmware. The steps to flash the Crazyflie with the latest firmware are discussed [https://www.bitcraze.io/documentation/tutorials/getting-started-with-crazyflie-2-x/ here].


The Crazyflie client is used for controlling the Crazyflie, flashing firmware, setting parameters and logging data. The main UI is built up of several tabs, where each tab is used for a specific functionality. We used this [https://wiki.bitcraze.io/doc:crazyflie:client:pycfclient:index#loco_positioning link] to get started with first manual flight of the drone and to develop an understanding of Crazyflie Client. Assisted flight mode is recommended as an initial manual testing mode which is explained [https://www.bitcraze.io/documentation/tutorials/getting-started-with-flying-using-lps/ here]. But before this assisted flight mode is executed, loco-positioning system needs to be setup as explained in next section.
The Crazyflie client is used for controlling the Crazyflie, flashing firmware, setting parameters and logging data. The main UI is built up of several tabs, where each tab is used for specific functionality. We used this [https://wiki.bitcraze.io/doc:crazyflie:client:pycfclient:index#loco_positioning link] to get started with the first manual flight of the drone and to develop an understanding of Crazyflie Client. [https://www.bitcraze.io/documentation/tutorials/getting-started-with-flying-using-lps/ Assisted flight mode] can be used to have a stable altitude and hovering as an initial manual flight testing mode.


==Autonomous Flight==
==Autonomous Flight==
To get started with autonomous flight, the pre-requisites are as follows:  
To get started with autonomous flight, the pre-requisites are as follows:  
* [https://www.bitcraze.io/documentation/tutorials/getting-started-with-loco-positioning-system/ Loco Positioning System]: Please refer to “Loco Positioning System Section” for more details. The link explains the whole setup of loco-positioning system.  
* [https://www.bitcraze.io/documentation/tutorials/getting-started-with-loco-positioning-system/ Loco Positioning System]: Please refer to "[http://cstwiki.wtb.tue.nl/index.php?title=Implementation_MSD19#Local_Positioning_System_.28Loco_Deck.29 Loco Positioning System section]" for more details. The link explains the whole setup of the loco-positioning system.  
* Linux (Ubuntu 16.04)  
* Linux (Ubuntu 16.04)  
* Python Scripts: We used autnomousSequence.py file from crazyflie python library. We found this script to be the starting point of autonomous flight.
* Python Scripts: We used [https://github.com/bitcraze/crazyflie-lib-python/blob/master/examples/autonomousSequence.py ''autnomousSequence.py''] file from the Crazyflie Python library. We found this script to be the starting point of autonomous flight.


This [https://gist.github.com/madelinegannon/ba38a89c210d011a3ae224651b8a1aee link] was also used develop a comprehensive understanding of autonomous flight. After setting up the LPS, modifications in the python script of autonomousSequence.py file were made to adjust it according to desired deliverables.
This [https://gist.github.com/madelinegannon/ba38a89c210d011a3ae224651b8a1aee link] was also used to develop a comprehensive understanding of autonomous flight. After setting up the LPS, modifications in the python script of ''autonomousSequence.py''  file were made to adjust it according to desired deliverables. The video below shows the Crazyflie hovering autonomously while changing yaw over time.




<center>[[File:Autonomous Flight.png|center|750px|link=https://www.youtube.com/watch?v=u2JPi79YcQE]]</center>
<center>[[File:Autonomous Flight image.png|center|750px|link=https://www.youtube.com/watch?v=04ycp__ziBA&feature=youtu.be]]</center>


==Modifications==
==Modifications==
The following modifications were made in the autonomousSequence.py file.  
The following modifications were made in the ''autonomousSequence.py'' file.  
* Data Logging of Crazyflie Position from Path Planning and Simulator to CSVs
* Ball Position Extraction from Visualizer Data  
* [http://cstwiki.wtb.tue.nl/index.php?title=Implementation_MSD19#Path_Planning Path Planning]
* Development of Path Planning Algorithm which takes the Visualizer data and converts it to drone position data
* Drone Position data extraction and sending it to Visualizer for visual representation


These modifications can be observed by comparing the original autonomousSequence.py file with our file [https://gitlab.tue.nl/autoref/autoref_system.git here]. The difference is easily visible and understandable. This is the git-repository of our work. The modified autnomousSequence.py file can be accessed in '''Motion Control''' folder.
The [https://gitlab.tue.nl/autoref/autoref_system/-/blob/master/Motion%20Control%20/Autonomous.py ''modified_autonomousSequence.py''] file was developed in parallel with the project. The modifications were made as we were progressing through the project and new observations and suggestions were coming to light. 
 
The original [https://github.com/bitcraze/crazyflie-lib-python/blob/master/examples/autonomousSequence.py ''autonmousSequence.py''] file will develop the basic understanding of autonomous flight parameters and its comparison with the ''modified_autonomousSequence.py'' is advised to understand and follow through the changes and modifications.


==Troubleshooting==
==Troubleshooting==
The drone positioning parameters i.e. roll, pitch and yaw are not stable. The solution is to trim the parameters which can be seen in [https://wiki.bitcraze.io/doc:crazyflie:client:pycfclient:index#loco_positioning Firmware Configuration] headline in the following link. For autonomous flights, issues like updating the anchor nodes and assigning them identification numbers may appear in Windows, but they can be solved by updating the nodes in Linux.
The drone positioning parameters, i.e. roll, field and yaw are not stable. The solution is to trim the parameters which can be seen in the Firmware Configuration headline in the following [https://wiki.bitcraze.io/doc:crazyflie:client:pycfclient:index#loco_positioning link]. For autonomous flights, issues regarding updating the anchor nodes and assigning them identification numbers may appear in Windows, but they can be solved by updating the nodes in Linux.


=Localization=
=Localization=
<span style="color:red">
<span style="color:black">
'''Need introduction here.'''
Mobile robots require a solution to determine a spatial relationship with its environment in order to fulfil any motion command. Localization is a backbone component of such robots as it covers the process of depicting a position (and orientation) estimation of the moving robot at a given time. Using sensors and the onset information of the environment a robot will be able to create a spatial relationship with its surroundings. This relationship is in the kind of a transformation between the world coordinate system and the robot local reference. From a transformation, the pose and attitude of the robot can be computed. Additional challenges on localization come from the fact that sensor data contains a level of error and need to be filtered/processed to account for accurate measurements.
 
Since an individual sensor would not be adequate for localising, the Crazyflie 2.0 offers numerous options apart from its standard hardware configuration. By default, it is equipped with an IMU. For the project, several options were considered before moving on to implementation and testing their capabilities; (1) Camera and markers (Optitrack), (2) Ultra-wideband positioning (LPS), (3) Optical motion detection (Flowdeck) or a combination of (2) and (3).
The intention of the project group was to avoid any platform-specific dependencies that could lead to difficulties in integration. Thus, the focus was to either use LPS alone or combine with Flowdeck, considering limitations thereof.
 
The subsequent sections describe the basics of drone dynamics in which localisation plays essential role followed by a summary of the performance achieved by each available option.
 
</span>
</span>
==Drone Dynamics==


==Local Positioning System (Loco Deck)==
==Local Positioning System (Loco Deck)==
The core of localization tool used for the drone is based on a purpose-built Loco Positioning system (LPS) that provides a complete hardware and software solution by Bitcraze. This system comes with a documentation regarding installation, configuration, and technical information in the [https://wiki.bitcraze.io/doc:lps:index online directory]. Before starting, the following preparations are made:
The core of the localization tool used for the drone is based on a purpose-built Loco Positioning system (LPS) that provides a complete hardware and software solution by Bitcraze. This system comes with documentation regarding installation, configuration, and technical information in the [https://wiki.bitcraze.io/doc:lps:index online directory]. Before starting, the following preparations are made:
* 1 Loco positioning deck installed on Crazyflie  
* 1 Loco positioning deck installed on Crazyflie  
* 8 Loco positioning nodes positioned within the room  
* 8 Loco positioning nodes positioned within the room  
Line 61: Line 91:


==Loco Deck + Flow Deck==
==Loco Deck + Flow Deck==
Integration of sensor information occurs automatically as drone firmware can identify which types of sensors are available. Subsequently, the governing [https://www.bitcraze.io/2016/05/position-control-moved-into-the-firmware/ controller] handles the data accordingly. To accept more sensor input, the Crazyflie utilizes an [https://idsc.ethz.ch/education/lectures/recursive-estimation.html Extended Kalman Filter]. The information flow from component to component at low level can be seen below;
Integration of the sensor information occurs automatically as drone firmware can identify which types of sensors are available. Subsequently, the governing [https://www.bitcraze.io/2016/05/position-control-moved-into-the-firmware/ controller] handles the data accordingly. To accept more sensor input, the Crazyflie uses an [https://idsc.ethz.ch/education/lectures/recursive-estimation.html Extended Kalman Filter]. The information flow from components to components at the low level can be seen below;
 
==Recommendations and Troubleshooting==
* It is vital to have sensors operating in proper environmental conditions. Such as non-reflective floor surface for (Flowdeck) laser ranger, textured surface for (Flowdeck) camera/ laser ranger, empty room for clear radio signalling to (LPS) UWBs.
 
* For packaging purposes of the battery, Flowdeck and LPS deck it is better to use long pins such that proper power and signal distribution is supported. If not, the contact pins for mounting these devices becomes only marginally sufficient and at some points will not power the devices properly.
 
* Stable flight can be achieved if at least 4 anchors are identified so to make sure there is sufficient coverage over the (Tech United) field it is best to use 8 anchors. With this set up there is a better chance that range data will be continuously pinged from the Crazyflie 2.0 deck and back.
 
* LPS and Flowdeck together when used especially with TWR mode the Loco deck crashes after a while. The issue also raised in [https://forum.bitcraze.io/viewtopic.php?t=3150 ticket] and [https://forum.bitcraze.io/viewtopic.php?t=3836 another]. If encountered, [http://bitcraze/crazyflie-firmware: Issue #368 re-flash the drone]. <span style="color:red"> '''Link does not work.'''</span>
 
* While testing it has sometimes been observed that beacons on ground level do not communicate with Client at start of connection. A [https://forum.bitcraze.io/viewtopic.php?f=16&t=4215 ticket] has been opened concluding some alternative solutions in the forum.
 
* Some parameter setting could be changed to test in the CF Firmware in cases which EKF is getting confused with conflicting data from flow and the LPS at the same time. Things to try could be to increase the standard deviation: [https://github.com/bitcraze/crazyflie-firmware/blob/0c26532/src/deck/drivers/src/flowdeck_v1v2.c#L94-L95 For Flow sensor], [https://github.com/bitcraze/crazyflie-firmware/blob/866903e/src/deck/drivers/src/zranger2.c#L47-L50 For Range sensor], [https://github.com/bitcraze/crazyflie-firmware/blob/2019.09/src/deck/drivers/src/lpsTwrTag.c#L260 For UWB data parameter]


=Path Planning=
=Path Planning=
Due to the outbreak of COVID-19, our working environment changed drastically, and we cannot get access to the pitch at Tech United in the latter stage of our project. Therefore, we first design our path planning method in the pitch of the simulator, and then we transfer the planned path to fit the reference frame at the real pitch at Tech United. Two methods are designed by us and are described as below.
Path planning refers to providing a set of poses (x, y, z and yaw) for the drone to go to at any time step. We first design our path planning method in the field of the visualizer, and then we transfer the planned path to fit the reference frame at the real field at Tech United. Two methods are designed by us and are described below.


==Algorithm 1 --- Drones moving on the lines==
==Algorithm 1 --- Drones moving parallel to the sidelines==
In this method, two drones are used. They are positioned at a specific height outside the pitch, respectively moving on the lines parallel to the sidelines of the pitch with yaw movements. The drones are supposed to move so that the ball is always around the centre of their camera views. Since the algorithm works the same for the two drones, we only show the computation of the planned path of one drone.
In this method, two drones are used so that the ball can be seen almost all the time. They are positioned at a specific height outside the field, respectively moving on the lines parallel to the sidelines of the field with yaw movements. The drones are supposed to move so that the ball is always around the centre of their camera views. Since the algorithm works the same for the two drones, we only show the computation of the planned path of one drone.


===Assumptions===
To facilitate our path planning, several assumptions are made as follows:
To facilitate our path planning, several assumptions are made as follows:
* The ball is assumed to be on the ground all the time.
* The ball is assumed to be on the ground all the time.
Line 90: Line 108:


<center>[[File:Refereance frame in the simulator.png|500 px|Refereance frame in the simulator]]</center>
<center>[[File:Refereance frame in the simulator.png|500 px|Refereance frame in the simulator]]</center>
<center>The illustration of the drones' positions and the pitch in the simulator</center>
<center>The illustration of the drones' positions and the field in the Visualizer</center>


The dimension of the pitch is 18m x 12m, and the origin is at the centre of the pitch.  
The dimension of the field is 18m x 12m, and the origin is at the centre of the field.


Since the drone moves on the lines parallel to the sidelines and on the same altitude, the x and z-coordinate references of the drone [[File:20200323_SG_barx^d_r.png‎]] and [[File:20200323_SG_barz^d_r.png‎]] are fixed. In this way, only y-coordinate and yaw angle change.In our algorithm, we set [[File:20200323_SG_barx^d_r=7.png‎]] (the value is -7 for the other drone) and [[File:20200323_SG_barz^d_r=2.png]].
===Algorithm===
 
Since the drone moves on the lines parallel to the sidelines and the same altitude, the x and z-coordinate references of the drone [[File:20200323_SG_barx^d_r.png‎]] and [[File:20200323_SG_barz^d_r.png‎]] are fixed. In this way, only y-coordinate and yaw angle change.In our algorithm, we set [[File:20200323_SG_barx^d_r=7.png‎]] (the value is -7 for the other drone) and [[File:20200323_SG_barz^d_r=2.png]].


The following notations are made:
The following notations are made:
Line 110: Line 130:
The distance between  [[File:20200323_SG_Bk+1_simple.png]]  and  [[File:20200323_SG_Dk_simple.png]] is
The distance between  [[File:20200323_SG_Bk+1_simple.png]]  and  [[File:20200323_SG_Dk_simple.png]] is


<center>[[File:Equation 2 SG.png|300 px|Equation 2]]</center>
<center>[[File:Equation 2 SG.png|280 px|Equation 2]]</center>


The path planning method is then described as follows:
The path planning method is then described as follows:
Line 116: Line 136:
We assume there is a circle, with a radius of [[File:20200323_SG_R.png]], whose centre is [[File:20200323_SG_Bk+1_simple.png]].  
We assume there is a circle, with a radius of [[File:20200323_SG_R.png]], whose centre is [[File:20200323_SG_Bk+1_simple.png]].  


Then we make the decision whether we rotate or move (or both) based on the relationship between dist and [[File:20200323_SG_R.png]]:
Then we decide whether we rotate or move (or both) based on the relationship between dist and [[File:20200323_SG_R.png]]:


1. If dist < R:
1. If dist < R:
Line 131: Line 151:


::* If [[File:20200323_SG_theta04636another.png‎]] (the ball is far away from the drone and is away from the centre of the drone’s view):
::* If [[File:20200323_SG_theta04636another.png‎]] (the ball is far away from the drone and is away from the centre of the drone’s view):
::Under this circumstance, the drone can track the y-coordinate of the ball. We can set the drone reference at the sampling time  k+1 as [[File:20200323_SG_bary^s_k+1=ddd25.png]]. In this scenario, the yaw reference changes as well [[File:20200324_SG_theta_last.png‎]].
:: Under this circumstance, the drone can track the y-coordinate of the ball. We can set the drone reference at the sampling time  k+1 as [[File:20200323_SG_bary^s_k+1=ddd25.png]]. [[File:Ydmax.png]] is the maximum distance that the drone can travel per second. Since the sampling frequency in the Visualizer is between 16 Hz and 20 Hz, we set [[File:20200325_SG_ydmax25.png‎]] as the distance that a drone can go in a sampling period. In this scenario, the yaw reference changes as well [[File:20200324_SG_theta_last.png‎]].


==Algorithm 2==
The implementation of the algorithm can be found [https://gitlab.tue.nl/autoref/autoref_system/-/blob/master/Path_Planning/SG_path_planning_algorithm_degree_references_1.py here] and [https://gitlab.tue.nl/autoref/autoref_system/-/blob/master/Path_Planning/SG_path_planning_algorithm_degree_references_2.py here].
The objective of this path planning algorithm is to '''find the shortest path for the drone''' while keeping the ball in the field of view. This is to minimise the mobility of the drone under given performance constraints to ensure a stable view from the onboard camera. This is done by keeping the ball's position as reference and thereafter, using the ball velocity to predict the future ball position.
 
==Algorithm 2 -- Drone moving in a circle==
The objective of this path planning algorithm is to '''find the shortest path for the drone''' while keeping the ball in the field of view. This is to minimise the mobility of the drone under given performance constraints to ensure a stable view from the onboard camera. This is done by keeping the ball's position as a reference and thereafter, using the ball velocity to predict the future ball position.
 
The reason to implement a second algorithm to capture the area of interest was mainly to test, apply and compare different strategies that work out best for every kind of game data. ''Drone in a circle'' is not only a good algorithm to capture the point of interest in a visualiser but also in a real game that uses a camera sensor to get the input data.


===Assumptions===
===Assumptions===
* The altitude, z<sub>drone</sub> of the drone is same throughout the duration of the game.
* The altitude, [[File:Capure1.png|45 px|Capure 1]] of the drone is same throughout the duration of the game.
* The ball is always on the ground, i.e., z<sub>ball</sub> = 0.
* The ball is always on the ground, i.e., [[File:Capure2.png|60 px|Capure 2]].
* The drone encounters no obstacles at altitude, z<sub>drone</sub>.
* The drone encounters no obstacles at altitude, [[File:Capure1.png|45 px|Capure 1]].
 
===Algorithm===
Let [[File:Capure3.png|17 px|Capure 3]] and [[File:Capure4.png|15 px|Capure 4]] be the radius of the circle around the ball, and the distance of the drone from the ball respectively. The drone holds its current position for [[File:Capure5.png|50 px|Capure 5]]  and tracks the ball as [[File:Capure4.png|15 px|Capure 4]] exceeds [[File:Capure3.png|17 px|Capure 3]] as shown in Fig below.
 


===Solution===
<center>[[File:Schematic representation of drone in a circle 1.png|600 px|Schematic representation of drone in a circle]]</center>
Let R and D be the radius of the circle around the ball, and the distance of the drone from the ball respectively. The drone holds its current position for D < R and tracks the ball  as D exceeds R as shown in Fig below.


Let [[File:Capure6.png|120 px|Capure 6]] be the position of the ball at sampling time [[File:Capure7.png|90 px|Capure 7]] [[File:Capure8.png|52 px|Capure 8]] be the sampling position of the ball at sampling time [[File:Capure9.png|10 px|Capure 9]]. The predicted position of the ball is therefore given by the following equation:


<center>[[File:Schematic representation of drone in a circle.png|600 px|Schematic representation of drone in a circle]]</center>
<center>[[File:Equation 1.png|450 px|Equation 1]]</center>


Let B<sub>k-1</sub> = (x<sup>b</sup><sub>k-1</sub>, y<sup>b</sup><sub>k-1</sub>) be the position of the ball at sampling time (k - 1), B<sub>k</sub> =
<center>[[File:Equation 2.png|450 px|Equation 2]]</center>
(x<sup>b</sup><sub>k</sub>; y<sup>b</sup><sub>k</sub>) be the sampling position of the ball at sampling time k. The predicted position of the ball is therefore given by the following equation:


<center>[[File:Equation 1.png|500 px|Equation 1]]</center>
where [[File:Capure10.png|9 px|Capure 10]] is the time taken by the drone to travel from position [[File:Capure11.png|32 px|Capure 11]] to [[File:Capure12.png|18 px|Capure 12]]. Distance, [[File:Capure13.png|13 px|Capure 13]] is then defined as follows:


<center>[[File:Equation 2.png|500 px|Equation 2]]</center>
<center>[[File:Equation3.png|400 px|Equation 3]]</center>


where t is the time taken by the drone to travel from position B<sub>k-1</sub> to B<sub>k</sub>. Distance, D is then defined as follows:
[[File:Capure14.png|120 px|Capure 14]] are the reference coordinates for the drone to achieve within time period, [[File:Capure10.png|9 px|Capure 10]] and is denoted by the following equation:


<center>[[File:Equation 3.png|400 px|Equation 3]]</center>
<center>[[File:Equation4.png|380 px|Equation 4]]</center>


Dref = (x<sup>d</sup><sub>ref</sub> ; y<sup>d</sup><sub>ref</sub> ) are the reference coordinates for the drone to achieve within time period, t and is denoted by the following equation:
<center>[[File:Equation5.png|380 px|Equation 5]]</center>


<center>[[File:Equation 4.png|500 px|Equation 4]]</center>
where [[File:Capure15.png|50 px|Capure 15]] is the maximum speed of the drone. The yaw reference for the drone, [[File:Capure16.png|50 px|Capure 16]] is given by the following equation:


<center>[[File:Equation 5.png|500 px|Equation 5]]</center>
<center>[[File:Equation6.png|220 px|Equation 5]]</center>


The error between the reference position, D<sub>ref</sub> and the current position, D<sub>k</sub> is estimated using the performance constraints of the Crazyflie and fed back to the algorithm to compute D<sub>k+1</sub>. The error terms are estimated as follows:
The [[File:Capure18.png|130 px|Capure 18]] are then fed to the drone to move around in a circle and capture the area of interest.


<center>[[File:Equation 6.png|250 px|Equation 6]]</center>
'''NOTE''': Since the visualizer has limitations to properly reproduce the yaw movement, the demonstration of the drone is a circle cannot be demonstrated and tested with the visualizer at this point. The implementation of this algorithm can be found [https://gitlab.tue.nl/autoref/autoref_system/-/blob/master/Path_Planning/pathplanning_AK_circle.py here].


<center>[[File:Equation 7.png|250 px|Equation 7]]</center>
==Transferring the coordinate in the Visualizer reference frame to that in the beacon reference frame==
The dimension of the field in the Visualizer is [[File:20200323 SG 18mx12m.png|60px|18mx12m]], and the origin of the Visualizerframe is at the centre of the field. The dimension of the field at Tech United is [[File:20200323 SG 12mx8m.png|60px|12m x 8m]], and the origin of the beacon frame is at the centre of the beacon 0. Therefore, the planned path in the Visualizer cannot be applied in reality, unless we transfer the planned path in the Visualizer into that in the beacon frame. The transformation is depicted below.


<center>[[File:Equation 8.png|350 px|Equation 8]]</center>
<center>[[File:Transfer Coordinate.png|700 px|Transfer Coordinate]]</center>


Therefore, the reference position, D<sub>ref</sub> is computed as follows:
Since we only consider this problem in the 2D frame, we do not transfer the z-coordinate.


<center>[[File:Equation 9.png|350 px|Equation 9]]</center>
Assume that the coordinate in the Visualizer reference frame is [[File:20200323 SG D=(x,y,z,yaw).png|120 px|D=(x,y,z,yaw)]], and the coordinate in the beacon reference frame is [[File:Equation 4 SG.png|200 px|Equation 4]] .


<center>[[File:Equation 10.png|350 px|Equation 10]]</center>
=Visualization=
The purpose of implementing a visualizer is to verify and validate the path planning algorithm. To fulfill the purpose, we took the previous game of Tech United as our test case. A virtual previous game was played on the visualizer and the field of view simulated the drone camera view.


The drone reference position is then updated at every sampling frequency of the Visualiser that is also used to provide the information of ball position in the soccer field.
Before describing how the visualizer works, we first clarify how the previous game data was stored. The whole dataset was in a matrix form, the data for each timestamp, such as ball location, turtlebot location, and game states were stored into a column vector. All the column vectors representing different timestamps were concatenated time sequentially together and form the matrix of previous game data.


==Transferring the coordinate in the simulator reference frame to that in the beacon reference frame==
The visualizer extracts the previous game data from each column to form a frame, by sequentially forming frames from the columns, a previous game is virtually replayed. Considering the compatibility with the data structure of previous game data, we decided to implement the visualizer by modifying the Tech United simulator, which is developed in MATLAB.
The dimension of the pitch in the simulator is [[File:20200323 SG 18mx12m.png|60px|18mx12m]], and the origin of the simulator frame is at the centre of the pitch. The dimension of the pitch at Tech United is [[File:20200323 SG 12mx8m.png|60px|12m x 8m]], and the origin of the beacon frame is at the centre of the beacon 0. Therefore, the planned path in the simulator cannot be applied in reality, unless we transfer the planned path in the simulator into that in the beacon frame. The transformation is depicted below.


<center>[[File:Transfer Coordinate.png|700 px|Transfer Coordinate]]</center>
There were two main modifications described below.
 
==Previous game data extraction==
To extract the ball position from previous game data and transfer it to the path planner, we saved the ball position into matrix form while concurrently using it for ball displaying. The matrix then outputted as a csv file to be transferred. A function was built to implement the explained task.
 
==Programmatically control the simulated camera view of drone==
To simulate the drone camera view, we had to manipulate the camera position and the orientation of the camera. The camera position was assumed as the drone position, which can be directly retrieved from the path planner as coordinate x, y, and z.


Since we only consider this problem in the 2D frame, we do not transfer the z-coordinate.
<center>''P<sub>Camera</sub> = P<sub>Drone</sub>''</center>


Assume that the coordinate in the simulator reference frame is [[File:20200323 SG D=(x,y,z,yaw).png|120 px|D=(x,y,z,yaw)]], and the coordinate in the beacon reference frame is [[File:Equation 4 SG.png|200 px|Equation 4]] .
On the other hand, in the MATLAB environment, the orientation of the camera can only be manipulated by assigning a target point  ''P<sub>Target</sub>''. The target point  ''P<sub>Target</sub>''  can be an arbitrary point along the direction we intend to oriented to. We defined  ''P<sub>Target</sub>''  as the point one meter away from the camera. As a result, ''P<sub>Target</sub>''  was derived from the formula below. The vector '''''V''''' represents the normalized vector of vector indicating Target to Camera.


=Simulation=
<center>''P<sub>Camera</sub> = P<sub>Drone</sub>'' - '''''V''''' </center>  
<span style="color:red">
'''Need introduction here.'''
</span>


==Previous Game Data Extraction==
To calculate '''''V''''', we needed the yaw angle of the drone θ<sub>1</sub> and the pitch angle of the camera θ<sub>2</sub>. The yaw angle of the drone θ<sub>1</sub> was assigned by the path planner. On the other hand, the pitch angle of the camera θ<sub>2</sub> was calculated. Further description of both angles can be found below.
To demonstrate the performance of our system, we planned to fly the drone both in the virtual world and the physical world. The virtual drone is for demonstrating that the output from our path planner is practical, and the physical drone is for demonstrating that our capability of flying the drone autonomously according to the output of the path planner.  


To describe the whole scenario in detail. In the virtual world, a previous game of Tech United will be played, and the drone will fly around the field according to the output from the path planner. On the monitor, what the camera on the drone is filming will be shown. On the other hand, in the physical world, a drone will also be flying according to the command from the path planner, but there will be no game playing.  
For θ<sub>1</sub>, 0<sup>°</sup> means the drone is facing toward the field. As there were two drones, there were two θ<sub>1</sub> from the path planner. Worth noticing is that as the two drones were facing opposite directions, the definition of  0<sup>°</sup> of these two yaw angles were also opposite to each other.


To realize the above-mentioned scenario, we need to extract the ball position from previous game data and transfer it to the path planner. In the beginning, we tried to retrieve the ball position from the data file loaded when replaying the previous game. After a few attempts, it turns out that it would be more straightforward to save the ball position into a matrix when it is used in the original program. A function is built to implement this.  
For θ<sub>2</sub>, we assumed that the camera’s pitch angle was constant. The value was derived with the assumption that the camera was oriented to the center of the field when located above the middle point of the sideline.


==Drone Camera View Control==
To show what the camera is supposed to be filming in the virtual world, we need the position and yaw angle of the drone, and the pitch angle of the camera when it is mounted on the drone. With these defined inputs, we built a function which will read those data from a CSV format file, and change the displayed view in the simulator accordingly.


=Perception=
<center>[[File:Image 1 WY.png|600 px|Image 1]]</center>
The fundamental goal is being able to referee the game of football. While testing for this project is a two vs. two game between two robots at the Tech United pitch facilities, the ultimate vision is that the system could be scaled and adapted for use in a real outdoor game between human beings. From the experience of previous projects, the client imposed the direction that the developed system uses drones with cameras. The main benefit of this being the relative convenience of setting up and the assumption that this dynamic capability would save cost by allowing for fewer cameras for comparable camera coverage. 


The work activity relating to the camera system was divided into two workstreams to allow for concurrent work activity. Firstly, the selection and integration of the hardware, such that it would not adversely affect the flight dynamics of the drone. Owing to the small size of the Crazyflie 2 drone, and the additional safety issues with using the larger drone variant with extra load capacity, we were restricted to using a small FPS camera because of latency issues with other options, as discussed in Yussuf's section. While this option allows for a live camera feed to an external referee, this option seemingly does not allow for further processing of those images without significant delay. So this option would only ever allow for the most basic of systems, requiring humans firmly in the driving seat of all decision making. While this simplification was deemed an acceptable compromise for the scope of this project, it is assumed that the project will be continued by others, and so this is an essential factor to consider. In this project, we also assumed that the position of the ball and players is known, as this data has been taken from previous games that have been recorded from the server. In the real case, this would not be available, and mechanisms to determine this input must be a part of the system itself. Intending to address both of those points, the second workstream relating to the camera system focused on obtaining information from the data captured in the video streams. As the first step in that direction, the specific objective here was focused on getting the ball position so that this could input into Song and Ankita's control software and also update the simulator views. At this stage, the player positions have not been considered, as this information is required for more granular decisions.
By applying θ<sub>1</sub> in the way as the figures below shown, '''''V'''''  for the two drones could be calculated as the formulas show. The two formulas are different because of the two θ<sub>1</sub> were defined in different coordinate systems. A function was built to implement the task described in this section.


==Workstream 1==
<center>[[File:Image 2 WY.png|500 px|Image 2]]</center>
The initial step in developing this interpretation aspect of the camera system was to construct a scale model of the real pitch. Owing to logistical reasons, such as availability of the actual pitch and distance from our office, this proved to be a useful and convenient tool in early-stage prototyping of ideas. From this, we determined a first attempt strategy of a fixed camera, independent of the drone, to capture the ball and whole pitch. Then by taking the homography, we could determine the world co-ordinate of the ball with respect to the pitch from the image space. Several issues where identified from conducting scale model testing, such as bright spots, occlusions, and changes in lighting condition. In order to overcome these issues, the first step would be to apply a mask to the image; this would block out the background so that only the pitch area would be considered. At this early stage, occlusions would just be accepted, and in such cases, the system would not be able to provide a decisive location for the ball. This was deemed to be acceptable because the dynamics of the game mean that occlusions are usually temporary, and the drone would only move with a quite significant change in ball position anyway. From testing on the model and the actual pitch, it was found that occlusions are not as substantial as was expected. Of course, the use of extra cameras would also further reduce this impact. To address the issue of changing light conditions, using Hue, Saturation, Value (HSV) color rather than RGB color significantly reduced the effect of this. For this first proof of concept in the specific test environment, a bright orange ball was used, and so we could expect high contrast with all other actors on the pitch; also, the light conditions at the Tech United facilities are well controlled. To improve system quality, several filters are applied to the image, such as erosion and dilation, and the position of the ball in the image is identified by blob detection and taking the centroid.   


<span style="color:red">
=Vision System=
'''image of the model pitch in the office here'''
The fundamental goal is to referee the game of football. While testing for this project is a two vs. two game between two robots at the Tech United field facilities, the ultimate vision is that the system could be scaled and adapted for use in a real outdoor game between human beings. From the experience of previous projects, the client imposed the direction that the developed system uses drones with cameras. The main benefit of this being the relative convenience of setting up and the assumption that this dynamic capability would save cost by allowing for fewer cameras for comparable camera coverage. 
</span>


It was found that the most convenient option would be to use the camera built into a mobile phone. From a practical point of view, this also has the benefit that everyone tends to carry a cellular phone around with them. In order to do this, the Epoccam app was used that allows the mobile phone to be used as a wireless webcam. It was found that if both the phone and laptop where connected to the Eduroam network, then there was no discernable latency issue. This was also tested using a mobile data hotspot, and this also proved to have excellent performance. In order to mount the mobile phone, a camera mount was constructed from a selfy-stick and a 3d printed base that allowed it to be secured to a scaffolding pole at the pitch site. On the pitch, testing showed that the delay and accuracy were both completely reasonable. At the extreme corners of the pitch from the camera, the system placed the ball within less than one meter of precision on a first attempt; this was deemed adequate just for informing the drone position. At the center of the pitch, the precision was within 20cm. Due to the coronavirus, further testing and refinement were not possible. There is, however, the scope for plenty of improvement if it should be needed. The camera was only placed 2m off the ground, and so this means that, at that height, at the extremes of the field, the pitch line angles are very acute. Also, the image quality was only set to low during that particular test. The testing that was done at the higher resolution showed no noticeable drop in latency.
The work activity relating to the camera system was divided into two workstreams to allow for concurrent work activity. 1) The selection and integration of the hardware, such that it would not adversely affect the flight dynamics of the drone. Owing to the small size of the Crazyflie 2 drone, and the additional safety issues with using the larger drone variant with extra load capacity, we were restricted to using a small FPV camera because of latency issues with other options, as discussed [http://cstwiki.wtb.tue.nl/index.php?title=Implementation_MSD19#Hardware here]. While this option allows for a live camera feed to an external referee, this option seemingly does not allow for further processing of those images without significant delay. So this option would only ever allow for the most basic of systems, requiring humans firmly in the driving seat of all decision making. While this simplification was deemed an acceptable compromise for the scope of this project, it is assumed that the project will be continued by others, and so this is an essential factor to consider. In this project, we also assumed that the position of the ball and players is known, as this data has been taken from previous games that have been recorded from the server. In the real case, this would not be available, and mechanisms to determine this input must be a part of the system itself. 2) Intending to address both of those points, other workstream relating to the camera system focused on obtaining information from the data captured in the video streams, which is the software aspect. As the first step in that direction, the specific objective here was focused on getting the ball position so that this could input into [http://cstwiki.wtb.tue.nl/index.php?title=Implementation_MSD19#Algorithm_1_---_Drones_moving_along_the_soccer_field_long_boundary algorithm 1] and [http://cstwiki.wtb.tue.nl/index.php?title=Implementation_MSD19#Algorithm_2_--_Drone_moving_in_a_circle_within_soccer_field algorithm 2] and also update the Visualizer views. At this stage, the player positions have not been considered, as this information is required for more granular decisions.


==Workstream 2==
==Hardware==
Drone's camera is a subsystem that fulfill the requirement to get the stream of the game from the drone. Additionally, the image streamed by drone's camera is also expected to obtain information from the actual field (e.g ball/player location). During the projects, three design options are considered and analyzed, see Table below.
The camera on the drone is the subsystem that fulfill the requirement to stream the gameplay from the drone point of view. Additionally, the image streamed by the camera on the drone is also expected to obtain information from the actual field (e.g ball/player location). During the projects, three design options are considered and analyzed, see Table below


<center>[[File:Vision System Choices.png|600 px|Vision System Choices]]</center>
<center>[[File:Vision System Choices.png|600 px|Vision System Choices]]</center>


The first option is analyzed by investigating the communication performance between raspberry pi and pc. The communication uses IP communication <span style="color:red">'''give ref link here.''' </span>. Some setting change is observed to verify the communication performance, such as changing from TCP protocol to UDP and use different wifi router. The result shows high latency with the fastest would be 0.6s. This shows that wireless communication is not reliable to give field information (e.g ball location), hence we leave this option out.  
The first option is analyzed by investigating the communication performance between raspberry pi and pc. The communication uses [https://picamera.readthedocs.io/en/release-1.10/recipes1.html IP communication]. Some setting change is observed to verify the communication performance, such as changing from TCP protocol to UDP and use different wifi router. The result shows high latency with the fastest would be 0.6s. This shows that wireless communication is not reliable to give field information (e.g ball location), hence we leave this option out.  


For the second option, it has a risk of processing burden in raspberry pi to handle communication and image processing. In addition, more work is required on the drone system (e.g the drone needs to be expanded).  
For the second option, it has a risk of processing burden in raspberry pi to handle communication and image processing. In addition, more work is required on the drone system (e.g the drone needs to be expanded).  
Line 237: Line 262:
* Connect skydroid receiver to pc run any webcam software/choose as second webcam for opencv.
* Connect skydroid receiver to pc run any webcam software/choose as second webcam for opencv.
* Set radio frequency in FPV camera into skydroid receiver frequency .
* Set radio frequency in FPV camera into skydroid receiver frequency .
==Software==
The initial step in developing this interpretation aspect of the camera system was to construct a scale model of the real field. Owing to logistical reasons, such as availability of the actual field and distance from our office, this proved to be a useful and convenient tool in early-stage prototyping of ideas. From this, we determined a first attempt strategy of a fixed camera, independent of the drone, to capture the ball and whole field. Then by taking the homography, we could determine the world co-ordinate of the ball with respect to the field from the image space. Several issues where identified from conducting scale model testing, such as bright spots, occlusions, and changes in lighting condition. In order to overcome these issues, the first step would be to apply a mask to the image; this would block out the background so that only the field area would be considered. At this early stage, occlusions would just be accepted, and in such cases, the system would not be able to provide a decisive location for the ball. This was deemed to be acceptable because the dynamics of the game mean that occlusions are usually temporary, and the drone would only move with a quite significant change in ball position anyway. From testing on the model and the actual field, it was found that occlusions are not as substantial as was expected. Of course, the use of extra cameras would also further reduce this impact. To address the issue of changing light conditions, using Hue, Saturation, Value (HSV) color rather than RGB color significantly reduced the effect of this. For this first proof of concept in the specific test environment, a bright orange ball was used, and so we could expect high contrast with all other actors on the field; also, the light conditions at the Tech United facilities are well controlled. To improve system quality, several filters are applied to the image, such as erosion and dilation, and the position of the ball in the image is identified by blob detection and taking the centroid.   
<center>[[File:Model Pitch.png|600 px|Model Pitch]]</center>
It was found that the most convenient option would be to use the camera built into a mobile phone. From a practical point of view, this also has the benefit that everyone tends to carry a cellular phone around with them. In order to do this, the Epoccam app was used that allows the mobile phone to be used as a wireless webcam. It was found that if both the phone and laptop where connected to the Eduroam network, then there was no discernable latency issue. This was also tested using a mobile data hotspot, and this also proved to have excellent performance. In order to mount the mobile phone, a camera mount was constructed from a selfy-stick and a 3d printed base that allowed it to be secured to a scaffolding pole at the field site. On the field, testing showed that the delay and accuracy were both completely reasonable. At the extreme corners of the field from the camera, the system placed the ball within less than one meter of precision on a first attempt; this was deemed adequate just for informing the drone position. At the center of the field, the precision was within 20cm. Due to the coronavirus, further testing and refinement were not possible. There is, however, the scope for plenty of improvement if it should be needed. The camera was only placed 2m off the ground, and so this means that, at that height, at the extremes of the field, the field line angles are very acute. Also, the image quality was only set to low during that particular test. The testing that was done at the higher resolution showed no noticeable drop in latency.
'''NOTE''': It is assumed that the ball remains on the ground. From analyzing gameplay footage, it is apparent that for the vast majority of cases where the ball is not on the ground is when a robot shoots. The most straightforward approach to deal with this more complicated scenario is to be directly above the goal looking down so that you also only need to consider a 2D problem. In the simulator video that uses server data collected from the combination of all the robot players, it can be seen that they also often lose track of the ball in this scenario. These use much higher quality equipment, and there a multiple of them, so it does not seem likely that this is something the drone could do. So a view from directly above would most likely be the most robust approach. This has not been investigated further because of the coronavirus.


=Integration=
=Integration=
This task integrates all the subsystem that follows the strategies/deliveries defined. For that we have two strategies/deliveries
This task integrates all the subsystem according to three deliveries defined. Those deliveries are defined as follows:
=== First Delivery: Reading from Visualizer data, translate it as drone setpoints sequence ===
 
 
The goal for this delivery is to verify the path planning algorithm in Visualizer. The plan is to extract the ball location data of previous game data (e.g to .csv file) and translate that into drone setpoint which will be equal to point of view location in Visualizer.  
 
The expected result would be the point of view in Visualizer that play a recorded game is equal to the setpoint generated by the path planning algorithm. The integration task for this delivery involves Visualizer, and path planning algorithm. In general, the task identified is to answer these questions:
# How path planning is implemented and get ball location from a recorded Tech United’s game.
# How the setpoints produced by Visualizer is read by Visualizer as a point of view.


==Path Planning and Crazyflie (Implemented and Not Verified)==
These questions are solved by logging the ball location simultaneously while the game is played. The path planning algorithm read this .csv file as a matrix of ball location and return another .csv file that contains a matrix of camera/drone location. The Visualizer then is modified to read .csv file with camera location and insert that as Visualizer's point of view.


==Path Planning and Simulator (Implemented and Verified)==
<center>[[File:Image 1 Y.png|800 px|Vision System Choices]]</center>
The goal for this strategy is to verify the path planning algorithm and drone behavior based on setpoints given (e.g response time, maximum speed). 


The plan is to extract the ball location data of previous game data (e.g to .csv file) and translate that into drone setpoint which will be equal to camera location in simulator. After the path planning is verified, these drone setpoint is implemented with crazyflie.  
===Second Delivery: Implement the drone setpoint from previous gameplay on the crazyflie===
The goal for this strategy is to verify the drone behavior based on setpoints given (e.g response time, maximum speed). Crazyflie read the .csv file of setpoint produced by previous delivery. This strategy shows the drone flies in the actual field based on the setpoint sequence generated, while the drone location is fed to simulator that playing a game data. The expected result would be the location of the camera in simulator is synchronized with the ground truth of drone location and hence the goals are achieved.  


[[File:Project Pipeline 1.png|200 px|center|Project Pipeline 1]]
<center>[[File:Image 2 Y.png|800 px|Vision System Choices]]</center>


This strategy will be the first delivery of the project where the drone flies in the actual field based on the setpoint sequence generated, while the drone location is fed to simulator that playing a game data. The expected result would be the location of the camera in simulator is synchronized with the ground truth of drone location and hence the goals are achieved. 


This integration task involves drone, simulator, and path planning subsystem. The sub-tasks which are addressed should be:
This integration task involves drone, Visualizer, and path planning subsystem. The sub-tasks which are addressed should be:
* Transform frame reference from Visualizer and drone
Since both use different frame reference, transforming the coordinate is required between loco positioning system (LPS) and Visualizer. We decided to add this functionality in the drone system: the drone transforms the setpoint to its LPS coordinate and transforms its ground truth position to Visualizer coordinate which is fed to Visualizer as camera position.
*Communication between drone and Visualizer
The Visualizer is run in the Matlab environment while the drone is in the Python environment. To enable transferring the data from the drone to Visualizer, two options are considered:
# Drone write a file (e.g .csv file) that contains drone actual location, and Visualizer read the file as Visualizer camera position
# Use socket communication, to communicate between the process
Both are feasible and tested with minimum code ([https://github.com/ysfsalman/python-matlab-socket-comm <socket communication>] [https://github.com/ysfsalman/csv-communication <csv communication>]). The second option has been tested with Crazyflie running. Following are the pros and cons of the options:


* Transform frame reference from simulator and drone. Since both use different frame reference, transforming the coordinate is required between loco positioning system(lps) and simulator. We decided to add this functionality in drone system: drone transform the setpoint to its lps coordinate and transform its ground truth position to simulator coordinate which is fed to simulator as camera position.
* Communication between drone and simulator The simulator is run in matlab enviroment while the drone is in python environment. To enable transferring the data from the drone to simulator, two options are considered:
# Drone write a file (e.g csv file) that contains drone actual location, and simulator read the file as simulator camera position.
# Use socket communication, to communicate between the process.
Both are feasible and tested with minimum code <get link here> [https://github.com/ysfsalman/python-matlab-socket-comm <socket communication>] [https://github.com/ysfsalman/csv-communication <csv communication>]. The second option has been tested with crazyflie running. Following are the pros and cons between the options:


<center>[[File:Table 1 Y.png|780 px|Vision System Choices]]</center>


<center>[[File:Path Planning and Simulator.png|center|750px|link=https://www.youtube.com/watch?v=u2JPi79YcQE]]</center>
The video below shows the result of integrating algorithm 1 with the visualizer.
<center>[[File:Second delivery 1 image.png|center|760px|link=https://youtu.be/pehmxfq5D9A]]</center>


==Perception, Path Planning and Simulator (Not Implemented and Not Verified)==
Figure shows how this strategy will look like. In the general planning we decide to use system out of the drone to get the ball location based on camera system consideration. Hence, we use a static camera to feed ball location into path planning algorithm that later will generate the drone set point.


[[File:Project Pipeline 2.png|200 px|center|Project Pipeline 2]]
The video below shows the result of integrating algorithm 2 with the visualizer.
<center>[[File:Second delivery 2 image.png|center|760px|link=https://youtu.be/owEOz6hkq8A]]</center>


Since the ball localizing system can be developed in any system, integration between ball localizing system is considered based on different scenarios.
===Final delivery: Get ball location from vision system, translate it as drone setpoints sequence===


[[File:Scenarios.png|600 px|center|Scanarios]]
<center>[[File:Image 3 Y.png|780 px|Vision System Choices]]</center>


=Testing=
The figure above shows how this strategy will look like. Based on the analysis for the camera on the drone, it is decided to use a static vision system to get the ball location. This static camera feeds ball location into the path planning algorithm that later will generate the drone set point.
The computed path planning algorithms are tested on the Visualiser and the hardware itself as explained as follows:


* For a given recorded game, the Simulator is capable of providing the ball coordinates which are then fed into the path planning algorithm. The python script for both the algorithms generate a .CSV file with information on drone's reference position along with the yaw angle of the drone. This is sufficient information to set a frame of view within the game and visualise the activity of the active players and the ball. More information on the implementation of this method can be found [http://cstwiki.wtb.tue.nl/index.php?title=Implementation_MSD19#Simulation here].
Since the ball localizing system can be developed in any system, integration between static vision system is considered based on different scenarios.


* After the successful implementation of the algorithm on the simulator, the reference drone position points are plugged into AutonomousSequence.py python script. These points are fed into the drone to have the ball in the field of view of drone's camera.  
<center>[[File:Table 2 Y.png|790 px|Vision System Choices]]</center>


In a real test case scenario, the drone gets the information of the ball's position using the onboard camera and objective of the drone would then be to keep the ball in its field of view.
The video below shows the result of integrating vision system with the crazyflie.
<center>[[File:Final delivery image.png|center|780px|link=https://youtu.be/MMiI8XViL-c]]</center>

Latest revision as of 22:35, 21 April 2020

After a comprehensive understanding of the problem, it was divided into sub-categories to assess and work efficiently and to have a modular system as a deliverable. Following milestones were set up to keep the project on track and achieve the desired goals step by step.

  • Hardware Assembly and manual flight of the drone
  • Autonomous Flight of the drone
  • Localization of the drone
  • Path Planning of the drone
  • Setting up of visualization environment
  • Perception system for the drone
  • Integration of sub-systems
  • Testing

Getting started with Crazyflie 2.X

Crazyflie is the mini-drone which we used during this project. The positive aspect of Crazyflie is that a considerable amount of research is available online with guidelines to undergo autonomous flights. Considering the scope of this project and economical viability, Crazyflie was a good choice. Getting started section will cover the following main headings:

  • Manual Flight
  • Autonomous Flight
  • Modifications
  • Troubleshooting

A recommendation in the start would be to follow the procedure from manual to autonomous flights. Jumping directly into autonomous flight mode is not advised as it will create a lot of ambiguity and lack of understanding of how the basic system works.

Manual Flight

This section explains in details on how to set up a Crazyflie 2.X drone starting from hardware assembly to first manual flight. We used Windows to continue with the initial setup of the software part for manual flight. However, Linux (Ubuntu 16.04) is preferred for the autonomous flight. The following additional hardware is required to set up a manual flight:

  • Bitcraze Crazyradio PA USB dongle
  • A remote control (PS4 Controller or Any USB Gaming Controller)

This link was used to get started with assembly and set up the initial flight requirements.

NOTE: It must be noted that the Crazyflie is running on its latest firmware. The steps to flash the Crazyflie with the latest firmware are discussed here.

The Crazyflie client is used for controlling the Crazyflie, flashing firmware, setting parameters and logging data. The main UI is built up of several tabs, where each tab is used for specific functionality. We used this link to get started with the first manual flight of the drone and to develop an understanding of Crazyflie Client. Assisted flight mode can be used to have a stable altitude and hovering as an initial manual flight testing mode.

Autonomous Flight

To get started with autonomous flight, the pre-requisites are as follows:

This link was also used to develop a comprehensive understanding of autonomous flight. After setting up the LPS, modifications in the python script of autonomousSequence.py file were made to adjust it according to desired deliverables. The video below shows the Crazyflie hovering autonomously while changing yaw over time.


Modifications

The following modifications were made in the autonomousSequence.py file.

  • Ball Position Extraction from Visualizer Data
  • Development of Path Planning Algorithm which takes the Visualizer data and converts it to drone position data
  • Drone Position data extraction and sending it to Visualizer for visual representation

The modified_autonomousSequence.py file was developed in parallel with the project. The modifications were made as we were progressing through the project and new observations and suggestions were coming to light.

The original autonmousSequence.py file will develop the basic understanding of autonomous flight parameters and its comparison with the modified_autonomousSequence.py is advised to understand and follow through the changes and modifications.

Troubleshooting

The drone positioning parameters, i.e. roll, field and yaw are not stable. The solution is to trim the parameters which can be seen in the Firmware Configuration headline in the following link. For autonomous flights, issues regarding updating the anchor nodes and assigning them identification numbers may appear in Windows, but they can be solved by updating the nodes in Linux.

Localization

Mobile robots require a solution to determine a spatial relationship with its environment in order to fulfil any motion command. Localization is a backbone component of such robots as it covers the process of depicting a position (and orientation) estimation of the moving robot at a given time. Using sensors and the onset information of the environment a robot will be able to create a spatial relationship with its surroundings. This relationship is in the kind of a transformation between the world coordinate system and the robot local reference. From a transformation, the pose and attitude of the robot can be computed. Additional challenges on localization come from the fact that sensor data contains a level of error and need to be filtered/processed to account for accurate measurements.

Since an individual sensor would not be adequate for localising, the Crazyflie 2.0 offers numerous options apart from its standard hardware configuration. By default, it is equipped with an IMU. For the project, several options were considered before moving on to implementation and testing their capabilities; (1) Camera and markers (Optitrack), (2) Ultra-wideband positioning (LPS), (3) Optical motion detection (Flowdeck) or a combination of (2) and (3). The intention of the project group was to avoid any platform-specific dependencies that could lead to difficulties in integration. Thus, the focus was to either use LPS alone or combine with Flowdeck, considering limitations thereof.

The subsequent sections describe the basics of drone dynamics in which localisation plays essential role followed by a summary of the performance achieved by each available option.

Drone Dynamics

Local Positioning System (Loco Deck)

The core of the localization tool used for the drone is based on a purpose-built Loco Positioning system (LPS) that provides a complete hardware and software solution by Bitcraze. This system comes with documentation regarding installation, configuration, and technical information in the online directory. Before starting, the following preparations are made:

  • 1 Loco positioning deck installed on Crazyflie
  • 8 Loco positioning nodes positioned within the room
  • Node fixed on stands 3D printed from makefile
  • USB power source for anchors
  • Ranging mode chosen as TWR

Overall hovering ability observed during hardware testing matches with what has been stated in company measurements as +/- 5 cm range.

Laser Range and Optical Sensor (Flow Deck 2.0)

An additional positioning component is a combination of VL53L0x Time of Flight sensor that measures ground distance and a PMW3901 optical flow sensor measures that ground planar movement. The expansion deck is plug and play. However, technical information is available.

Loco Deck + Flow Deck

Integration of the sensor information occurs automatically as drone firmware can identify which types of sensors are available. Subsequently, the governing controller handles the data accordingly. To accept more sensor input, the Crazyflie uses an Extended Kalman Filter. The information flow from components to components at the low level can be seen below;

Path Planning

Path planning refers to providing a set of poses (x, y, z and yaw) for the drone to go to at any time step. We first design our path planning method in the field of the visualizer, and then we transfer the planned path to fit the reference frame at the real field at Tech United. Two methods are designed by us and are described below.

Algorithm 1 --- Drones moving parallel to the sidelines

In this method, two drones are used so that the ball can be seen almost all the time. They are positioned at a specific height outside the field, respectively moving on the lines parallel to the sidelines of the field with yaw movements. The drones are supposed to move so that the ball is always around the centre of their camera views. Since the algorithm works the same for the two drones, we only show the computation of the planned path of one drone.

Assumptions

To facilitate our path planning, several assumptions are made as follows:

  • The ball is assumed to be on the ground all the time.
  • There is no obstacle to the drone on its height.
  • The ball velocity does not change in two consecutive sampling periods.

Below is the figure which depicts the method.

Refereance frame in the simulator
The illustration of the drones' positions and the field in the Visualizer

The dimension of the field is 18m x 12m, and the origin is at the centre of the field.

Algorithm

Since the drone moves on the lines parallel to the sidelines and the same altitude, the x and z-coordinate references of the drone and are fixed. In this way, only y-coordinate and yaw angle change.In our algorithm, we set (the value is -7 for the other drone) and .

The following notations are made:

At sampling time k-1, the ball position is .

At sampling time k, the ball position is , and the drone position is .

Since the ball velocity does not change in two consecutive sampling periods, the predicted ball position at sampling time k+1 can be computed as

Equation 1

which we denote as .

The distance between and is

Equation 2

The path planning method is then described as follows:

We assume there is a circle, with a radius of , whose centre is .

Then we decide whether we rotate or move (or both) based on the relationship between dist and :

1. If dist < R:

  • If ‎ (i.e. The ball is around the centre of the drone’s view), the drone does not have to move or rotate. Here .
Circle 1
In this way, and .
  • If (the ball may be still in the view of the drone but not close to the centre of the view), the drone has to rotate a bit, but its position does not change. Then and .
Circle 2

2. If dist > R:

  • If (i.e. The ball far away from the drone but is around the centre of the drone’s view), the drone does not have to move or rotate. In this way, and . The value is picked because we would like to keep the ball even closer to the centre of the drone's view when the ball is far away from the drone.
Circle 3
  • If (the ball is far away from the drone and is away from the centre of the drone’s view):
Under this circumstance, the drone can track the y-coordinate of the ball. We can set the drone reference at the sampling time k+1 as . is the maximum distance that the drone can travel per second. Since the sampling frequency in the Visualizer is between 16 Hz and 20 Hz, we set as the distance that a drone can go in a sampling period. In this scenario, the yaw reference changes as well .

The implementation of the algorithm can be found here and here.

Algorithm 2 -- Drone moving in a circle

The objective of this path planning algorithm is to find the shortest path for the drone while keeping the ball in the field of view. This is to minimise the mobility of the drone under given performance constraints to ensure a stable view from the onboard camera. This is done by keeping the ball's position as a reference and thereafter, using the ball velocity to predict the future ball position.

The reason to implement a second algorithm to capture the area of interest was mainly to test, apply and compare different strategies that work out best for every kind of game data. Drone in a circle is not only a good algorithm to capture the point of interest in a visualiser but also in a real game that uses a camera sensor to get the input data.

Assumptions

  • The altitude, Capure 1 of the drone is same throughout the duration of the game.
  • The ball is always on the ground, i.e., Capure 2.
  • The drone encounters no obstacles at altitude, Capure 1.

Algorithm

Let Capure 3 and Capure 4 be the radius of the circle around the ball, and the distance of the drone from the ball respectively. The drone holds its current position for Capure 5 and tracks the ball as Capure 4 exceeds Capure 3 as shown in Fig below.


Schematic representation of drone in a circle

Let Capure 6 be the position of the ball at sampling time Capure 7 Capure 8 be the sampling position of the ball at sampling time Capure 9. The predicted position of the ball is therefore given by the following equation:

Equation 1
Equation 2

where Capure 10 is the time taken by the drone to travel from position Capure 11 to Capure 12. Distance, Capure 13 is then defined as follows:

Equation 3

Capure 14 are the reference coordinates for the drone to achieve within time period, Capure 10 and is denoted by the following equation:

Equation 4
Equation 5

where Capure 15 is the maximum speed of the drone. The yaw reference for the drone, Capure 16 is given by the following equation:

Equation 5

The Capure 18 are then fed to the drone to move around in a circle and capture the area of interest.

NOTE: Since the visualizer has limitations to properly reproduce the yaw movement, the demonstration of the drone is a circle cannot be demonstrated and tested with the visualizer at this point. The implementation of this algorithm can be found here.

Transferring the coordinate in the Visualizer reference frame to that in the beacon reference frame

The dimension of the field in the Visualizer is 18mx12m, and the origin of the Visualizerframe is at the centre of the field. The dimension of the field at Tech United is 12m x 8m, and the origin of the beacon frame is at the centre of the beacon 0. Therefore, the planned path in the Visualizer cannot be applied in reality, unless we transfer the planned path in the Visualizer into that in the beacon frame. The transformation is depicted below.

Transfer Coordinate

Since we only consider this problem in the 2D frame, we do not transfer the z-coordinate.

Assume that the coordinate in the Visualizer reference frame is D=(x,y,z,yaw), and the coordinate in the beacon reference frame is Equation 4 .

Visualization

The purpose of implementing a visualizer is to verify and validate the path planning algorithm. To fulfill the purpose, we took the previous game of Tech United as our test case. A virtual previous game was played on the visualizer and the field of view simulated the drone camera view.

Before describing how the visualizer works, we first clarify how the previous game data was stored. The whole dataset was in a matrix form, the data for each timestamp, such as ball location, turtlebot location, and game states were stored into a column vector. All the column vectors representing different timestamps were concatenated time sequentially together and form the matrix of previous game data.

The visualizer extracts the previous game data from each column to form a frame, by sequentially forming frames from the columns, a previous game is virtually replayed. Considering the compatibility with the data structure of previous game data, we decided to implement the visualizer by modifying the Tech United simulator, which is developed in MATLAB.

There were two main modifications described below.

Previous game data extraction

To extract the ball position from previous game data and transfer it to the path planner, we saved the ball position into matrix form while concurrently using it for ball displaying. The matrix then outputted as a csv file to be transferred. A function was built to implement the explained task.

Programmatically control the simulated camera view of drone

To simulate the drone camera view, we had to manipulate the camera position and the orientation of the camera. The camera position was assumed as the drone position, which can be directly retrieved from the path planner as coordinate x, y, and z.

PCamera = PDrone

On the other hand, in the MATLAB environment, the orientation of the camera can only be manipulated by assigning a target point PTarget. The target point PTarget can be an arbitrary point along the direction we intend to oriented to. We defined PTarget as the point one meter away from the camera. As a result, PTarget was derived from the formula below. The vector V represents the normalized vector of vector indicating Target to Camera.

PCamera = PDrone - V

To calculate V, we needed the yaw angle of the drone θ1 and the pitch angle of the camera θ2. The yaw angle of the drone θ1 was assigned by the path planner. On the other hand, the pitch angle of the camera θ2 was calculated. Further description of both angles can be found below.

For θ1, 0° means the drone is facing toward the field. As there were two drones, there were two θ1 from the path planner. Worth noticing is that as the two drones were facing opposite directions, the definition of 0° of these two yaw angles were also opposite to each other.

For θ2, we assumed that the camera’s pitch angle was constant. The value was derived with the assumption that the camera was oriented to the center of the field when located above the middle point of the sideline.


Image 1

By applying θ1 in the way as the figures below shown, V for the two drones could be calculated as the formulas show. The two formulas are different because of the two θ1 were defined in different coordinate systems. A function was built to implement the task described in this section.

Image 2

Vision System

The fundamental goal is to referee the game of football. While testing for this project is a two vs. two game between two robots at the Tech United field facilities, the ultimate vision is that the system could be scaled and adapted for use in a real outdoor game between human beings. From the experience of previous projects, the client imposed the direction that the developed system uses drones with cameras. The main benefit of this being the relative convenience of setting up and the assumption that this dynamic capability would save cost by allowing for fewer cameras for comparable camera coverage.

The work activity relating to the camera system was divided into two workstreams to allow for concurrent work activity. 1) The selection and integration of the hardware, such that it would not adversely affect the flight dynamics of the drone. Owing to the small size of the Crazyflie 2 drone, and the additional safety issues with using the larger drone variant with extra load capacity, we were restricted to using a small FPV camera because of latency issues with other options, as discussed here. While this option allows for a live camera feed to an external referee, this option seemingly does not allow for further processing of those images without significant delay. So this option would only ever allow for the most basic of systems, requiring humans firmly in the driving seat of all decision making. While this simplification was deemed an acceptable compromise for the scope of this project, it is assumed that the project will be continued by others, and so this is an essential factor to consider. In this project, we also assumed that the position of the ball and players is known, as this data has been taken from previous games that have been recorded from the server. In the real case, this would not be available, and mechanisms to determine this input must be a part of the system itself. 2) Intending to address both of those points, other workstream relating to the camera system focused on obtaining information from the data captured in the video streams, which is the software aspect. As the first step in that direction, the specific objective here was focused on getting the ball position so that this could input into algorithm 1 and algorithm 2 and also update the Visualizer views. At this stage, the player positions have not been considered, as this information is required for more granular decisions.

Hardware

The camera on the drone is the subsystem that fulfill the requirement to stream the gameplay from the drone point of view. Additionally, the image streamed by the camera on the drone is also expected to obtain information from the actual field (e.g ball/player location). During the projects, three design options are considered and analyzed, see Table below

Vision System Choices

The first option is analyzed by investigating the communication performance between raspberry pi and pc. The communication uses IP communication. Some setting change is observed to verify the communication performance, such as changing from TCP protocol to UDP and use different wifi router. The result shows high latency with the fastest would be 0.6s. This shows that wireless communication is not reliable to give field information (e.g ball location), hence we leave this option out.

For the second option, it has a risk of processing burden in raspberry pi to handle communication and image processing. In addition, more work is required on the drone system (e.g the drone needs to be expanded).

Given the consideration above, the requirement for the vision system is concluded as to only streaming video (option 3). Therefore, an FPV camera is chosen as camera on crazyflie drone.

Final vision system setup:

  • Wolfwhoop WT05FPV Camera
  • Skydroid 5.7 dual receiver

Operation:

  • Connect the power cable from FPV camera with crazyflie battery.
  • Connect skydroid receiver to pc run any webcam software/choose as second webcam for opencv.
  • Set radio frequency in FPV camera into skydroid receiver frequency .


Software

The initial step in developing this interpretation aspect of the camera system was to construct a scale model of the real field. Owing to logistical reasons, such as availability of the actual field and distance from our office, this proved to be a useful and convenient tool in early-stage prototyping of ideas. From this, we determined a first attempt strategy of a fixed camera, independent of the drone, to capture the ball and whole field. Then by taking the homography, we could determine the world co-ordinate of the ball with respect to the field from the image space. Several issues where identified from conducting scale model testing, such as bright spots, occlusions, and changes in lighting condition. In order to overcome these issues, the first step would be to apply a mask to the image; this would block out the background so that only the field area would be considered. At this early stage, occlusions would just be accepted, and in such cases, the system would not be able to provide a decisive location for the ball. This was deemed to be acceptable because the dynamics of the game mean that occlusions are usually temporary, and the drone would only move with a quite significant change in ball position anyway. From testing on the model and the actual field, it was found that occlusions are not as substantial as was expected. Of course, the use of extra cameras would also further reduce this impact. To address the issue of changing light conditions, using Hue, Saturation, Value (HSV) color rather than RGB color significantly reduced the effect of this. For this first proof of concept in the specific test environment, a bright orange ball was used, and so we could expect high contrast with all other actors on the field; also, the light conditions at the Tech United facilities are well controlled. To improve system quality, several filters are applied to the image, such as erosion and dilation, and the position of the ball in the image is identified by blob detection and taking the centroid.


Model Pitch


It was found that the most convenient option would be to use the camera built into a mobile phone. From a practical point of view, this also has the benefit that everyone tends to carry a cellular phone around with them. In order to do this, the Epoccam app was used that allows the mobile phone to be used as a wireless webcam. It was found that if both the phone and laptop where connected to the Eduroam network, then there was no discernable latency issue. This was also tested using a mobile data hotspot, and this also proved to have excellent performance. In order to mount the mobile phone, a camera mount was constructed from a selfy-stick and a 3d printed base that allowed it to be secured to a scaffolding pole at the field site. On the field, testing showed that the delay and accuracy were both completely reasonable. At the extreme corners of the field from the camera, the system placed the ball within less than one meter of precision on a first attempt; this was deemed adequate just for informing the drone position. At the center of the field, the precision was within 20cm. Due to the coronavirus, further testing and refinement were not possible. There is, however, the scope for plenty of improvement if it should be needed. The camera was only placed 2m off the ground, and so this means that, at that height, at the extremes of the field, the field line angles are very acute. Also, the image quality was only set to low during that particular test. The testing that was done at the higher resolution showed no noticeable drop in latency.

NOTE: It is assumed that the ball remains on the ground. From analyzing gameplay footage, it is apparent that for the vast majority of cases where the ball is not on the ground is when a robot shoots. The most straightforward approach to deal with this more complicated scenario is to be directly above the goal looking down so that you also only need to consider a 2D problem. In the simulator video that uses server data collected from the combination of all the robot players, it can be seen that they also often lose track of the ball in this scenario. These use much higher quality equipment, and there a multiple of them, so it does not seem likely that this is something the drone could do. So a view from directly above would most likely be the most robust approach. This has not been investigated further because of the coronavirus.

Integration

This task integrates all the subsystem according to three deliveries defined. Those deliveries are defined as follows:

First Delivery: Reading from Visualizer data, translate it as drone setpoints sequence

The goal for this delivery is to verify the path planning algorithm in Visualizer. The plan is to extract the ball location data of previous game data (e.g to .csv file) and translate that into drone setpoint which will be equal to point of view location in Visualizer.

The expected result would be the point of view in Visualizer that play a recorded game is equal to the setpoint generated by the path planning algorithm. The integration task for this delivery involves Visualizer, and path planning algorithm. In general, the task identified is to answer these questions:

  1. How path planning is implemented and get ball location from a recorded Tech United’s game.
  2. How the setpoints produced by Visualizer is read by Visualizer as a point of view.

These questions are solved by logging the ball location simultaneously while the game is played. The path planning algorithm read this .csv file as a matrix of ball location and return another .csv file that contains a matrix of camera/drone location. The Visualizer then is modified to read .csv file with camera location and insert that as Visualizer's point of view.

Vision System Choices

Second Delivery: Implement the drone setpoint from previous gameplay on the crazyflie

The goal for this strategy is to verify the drone behavior based on setpoints given (e.g response time, maximum speed). Crazyflie read the .csv file of setpoint produced by previous delivery. This strategy shows the drone flies in the actual field based on the setpoint sequence generated, while the drone location is fed to simulator that playing a game data. The expected result would be the location of the camera in simulator is synchronized with the ground truth of drone location and hence the goals are achieved.

Vision System Choices


This integration task involves drone, Visualizer, and path planning subsystem. The sub-tasks which are addressed should be:

  • Transform frame reference from Visualizer and drone

Since both use different frame reference, transforming the coordinate is required between loco positioning system (LPS) and Visualizer. We decided to add this functionality in the drone system: the drone transforms the setpoint to its LPS coordinate and transforms its ground truth position to Visualizer coordinate which is fed to Visualizer as camera position.

  • Communication between drone and Visualizer

The Visualizer is run in the Matlab environment while the drone is in the Python environment. To enable transferring the data from the drone to Visualizer, two options are considered:

  1. Drone write a file (e.g .csv file) that contains drone actual location, and Visualizer read the file as Visualizer camera position
  2. Use socket communication, to communicate between the process

Both are feasible and tested with minimum code (<socket communication> <csv communication>). The second option has been tested with Crazyflie running. Following are the pros and cons of the options:


Vision System Choices

The video below shows the result of integrating algorithm 1 with the visualizer.


The video below shows the result of integrating algorithm 2 with the visualizer.

Final delivery: Get ball location from vision system, translate it as drone setpoints sequence

Vision System Choices

The figure above shows how this strategy will look like. Based on the analysis for the camera on the drone, it is decided to use a static vision system to get the ball location. This static camera feeds ball location into the path planning algorithm that later will generate the drone set point.

Since the ball localizing system can be developed in any system, integration between static vision system is considered based on different scenarios.

Vision System Choices

The video below shows the result of integrating vision system with the crazyflie.