@@ -17,31 +15,24 @@
This work involves the application of neural networks to program drones and thus test their performance in such systems. It will be implemented in two applications: initially, a line-following application, where the drone must follow a line in various circuits with the least possible error; and simultaneously, it will have to cross windows, which will consist of a mixed control where the drone will be teleoperated, but if the pilot wishes, the neural network will take control of the drone and attempt to cross the gates that appear in its field of vision.
-
-
Usually, classical programming algorithms are used for drone control. The control of these drones is typically done with cameras and various sensors that require intensive processing. This means that the drone needs a processing unit as a payload to handle all the data, or alternatively, the data must be processed at the ground station, which adds a delay in communications and potential errors that could affect a system that is critical to operate in real-time.
-
-
-
## Index
-
-
- [2023-tfg-adrian-madinabeitia](#2023-tfg-adrian-madinabeitia)
- [Index](#index)
- [Repository distribution](#repository-distribution)
- [Drone platforms](#drone-platforms)
+ - [Training](#training)
- [Follow line application](#follow-line-application)
- [Algorithmic expert pilot](#algorithmic-expert-pilot)
- [Getting the best model](#getting-the-best-model)
- - [Video](#video)
- [Gate travesing application](#gate-travesing-application)
+ - [1. Constant Altitude](#1-constant-altitude)
+ - [2. Variable Altitude](#2-variable-altitude)
- [Remote pilot control](#remote-pilot-control)
- - [Validation](#validation)
- [Licencia](#licencia)
-
---
---
@@ -50,17 +41,12 @@ Usually, classical programming algorithms are used for drone control. The contro
This project has two packages: one contains all the drone platforms [drone_plataforms](), and the other contains the behaviors programmed into the drone [drone_behaviors](). The drone is able to perform two applications: the line-following application and the gate-traversing application.
-
We follow the following [repository distribution](https://medium.com/analytics-vidhya/folder-structure-for-machine-learning-projects-a7e451a8caaa) for machine learning projects, along with the basic ROS structure.
-
-
---
---
-
-
## Drone platforms
We used de [aerostack2](https://github.com/aerostack2/aerostack2) platforms to utilize all the programmed behaviors in multiple drones. The platform launchers are in the package [drone_plataforms](). This package was created to separate the platform used from the behavior, thus allowing the developed software to be used in real drones in the future.
@@ -84,13 +70,55 @@ python3 python3 generateGateWorld.py
ros2 ros2 launch drone_platforms as2_sim_gates.launch.py
```
+---
+---
+
+## Training
+
+Bot applications follows the same training scripts so that is how the basic training script is called:
+
+0. Access to the src drone_behaviors directory:
+
+```bash
+cd /PATH_TO_PACKAGE/drone_behaviors/src/
+```
+
+1. Converting rosbags to standard format dataset:
+
+```bash
+python3 features/rosbag2generalDataset.py --rosbags_path ROSBAGS_PATH
+```
+
+1. Train a neural network with the standard format dataset, this script will receive the path of the dataset and will train the model specified in PATH_TO_NEW_NETWORK.tar:
+
+```bash
+
+## model: Selects the model the user wants to train
+## resume: Resume the training or creates a new one
+## network: Network path
+## Supports 4 dataset paths (--dp1, --dp2, --dp3, --dp4)
+
+python3 models/train.py --model [pilotNet|deepPilot] --resume [true or false] --network PATH_TO_NEW_NETWORK.tar --dp1 STD_DATASET_PATH1
+```
+
+2. Back-up script for saving different weights distribution in one training:
+
+```bash
+./utils/netCheckpointSaver.sh MODEL_PATH.tar
+```
+
+---
+---
+
## Follow line application
-### Algorithmic expert pilot
+For the imitation learning validation in this exercise, we collected a dataset with an algorithmic pilot, the dataset is available in the next [link](). Clicking the next image you can watch the demo video:
+
+[![Youtube video](https://img.youtube.com/vi/jJ4Xdin1gg4/0.jpg)](https://www.youtube.com/watch?v=jJ4Xdin1gg4)
-For the imitation learning validation in this exercise, we collected a dataset with an algorithmic pilot, the dataset is available in the next [link]().
+### Algorithmic expert pilot
-n this application, the [Pilot_Net](https://github.com/lhzlhz/PilotNet) network was used to control linear and angular velocity. The expert pilot is launched as:
+For this application, the [Pilot_Net](https://github.com/lhzlhz/PilotNet) network was used to control linear and angular velocity. The expert pilot is launched as:
```bash
#! First launch the platform
@@ -122,21 +150,27 @@ cd /PATH_TO_PACKAGE/drone_behaviors/utils
```
+After that you can use the automate training:
+
+```bash
+./generateNeuralPilot OUT_DIR MODEL_DIR
+```
+
+For forcing the exit of a tmux session:
+
+```bash
+./end_tmux.sh SESSION_NAME
+```
### Getting the best model
-To speed up the model selection process for this application, the following script was created. It executes a folder containing 𝑛 models and generates an image of the result for each on as the images below:
+To speed up the model selection process for this application, the following script was created. It executes a folder containing 𝑛 models and generates an image of the result for each on as the images below:
-### Video
-In this video you can see the neural network piloting the drone:
-
-
-
---
---
@@ -145,7 +179,17 @@ In this video you can see the neural network piloting the drone:
In this application we collected two datasets, one more generic for the pilotNet training (available in the next [link]()) and another one, more specialized in altitude movements for the deepPilot training (available in the next [link]())
+### 1. Constant Altitude
+
+In this video, you can see the drone maintaining a constant altitude:
+
+[![Watch the video](https://img.youtube.com/vi/l-WyA2C-4I4/0.jpg)](https://www.youtube.com/watch?v=l-WyA2C-4I4)
+### 2. Variable Altitude
+
+In this video, you can see the drone adjusting its altitude:
+
+[![Watch the video](https://img.youtube.com/vi/Q1zBNXdW7Ns/0.jpg)](https://www.youtube.com/watch?v=Q1zBNXdW7Ns)
### Remote pilot control
@@ -166,23 +210,11 @@ Launch this expert pilot with the following command:
ros2 launch drone_behaviors remoteControl.launch.py out_dir:=PATH net_dir:=PILOT_NET_MODEL deep_dir:=DEEP_PILOT_MODEL
```
-
-
-### Validation
-The only difference between the first application and this one was the expert pilot so the procedure in training was the same. This was the final result:
-
-1. Constant altitude:
-
-
-2. Variable altitude:
-
---
---
-
-
## Licencia
-