dgfann is a Distributed Genetic Algorithm framework for optimizing the configuration (number of layers, neuron types, number of neurons, etc.) of the neural networks (NN). dgfann finds the best configurations of NNs and train them using fann (https://github.com/libfann/fann).
We present here dgfann_lcad installation and use for Ubuntu 12.04.
dgfann_lcad was used in the paper Alberto F. De Souza, Jacson Rodrigues Correia da Silva, Filipe Mutz, Claudine Badue, Thiago Oliveira-Santos, "Simulating Robotic Cars Using Multi-Layer Neural Networks", submitted to the 2016 International Joint Conference on Neural Networks - IJCNN'2016. You can find the datasets used in the paper as well as extra results below.
We proposed a simulator for robotic cars based on two multi-layer recurrent neural networks [1]. These networks are intended to simulate the mechanisms that govern how a set of effort commands changes the car’s velocity and the direction it is moving. The first neural network receives as input a temporal sequence of current and previous throttle and brake efforts, along with a temporal sequence of the previous car’s velocities (estimated by the network), and outputs the velocity that the real car would achieve in the next time interval given these inputs. The second neural network estimates the arctangent of curvature (a variable related to the steering wheel angle [1]) that a real car would reach in the next time interval given a temporal sequence of current and previous steering efforts and previous arctangents of curvatures of the car. We have built and used a genetic algorithm framework for optimizing the configuration (number of layers, neuron types, number of neurons, etc.) of the neural networks that comprise the simulator. We evaluated the performance of our simulator using real-world datasets acquired using an autonomous robotic car (Fig. 1). Experimental results showed that our simulator was able to simulate in real time how a set of efforts influences the car’s velocity and arctangent of curvature. While navigating in a map of a real-world environment, our car simulator was able to emulate the velocity and arctangent of curvature of the real car with mean squared error of 2.2x10-3 (m/s)2 and 4.0x10-5 rad2, respectively [1].
Fig. 1. Intelligent and Autonomous Robotic Automobile (IARA), the robotic car platform simulated in this work (see it operating autonomously at https://youtu.be/LBM--2dAvyI). |
To install our genetic algorithm framework (dgfann) in Ubuntu:
- Install fann (http://leenissen.dk We are using our own fann version due to pull request #64 - libfann/fann#64)
- git clone https://github.com/LCAD-UFES/fann.git
- cd fann
- cmake -fopenmp .
- sudo make install
- sudo apt-get install swig
- sudo apt-get install python-dev
- sudo pip install fann2
- Install dgfann
- sudo pip install jsonrpclib
- sudo apt-get install python-pyfann
- sudo apt-get install gnuplot-x11
- git clone https://github.com/LCAD-UFES/dgfann_lcad.git
Note: An initial version of dgfann can be found at https://github.com/jeiks/gdfann
In [1], we have used IARA (Fig. 1, above) to collect samples for building a training and a test datasets, Tv and Tc (see sections III.B and III.C of [1]). For that, we have set IARA to run autonomously in typical operating situations and logged data according with Tv and Tc descriptions, with k = 120 for Tv and k = 40 for Tc. The number of input-output pairs, n, collected for Tv was equal to 5,366, and for Tc was equal to 7,683. After data collection, each dataset was shuffled and split into two parts, (a) and (b), where (a) received 1/3 of the samples and (b) 2/3 of the samples. Part (a) was used as the test sets, Tvte and Tcte, while part (b) was divided into the training (2/3 of (b)), Tvtr and Tctr, and validation (1/3 of (b)), Tvva and Tcva, sets.
These datasets are available in this repository and can be acessed in the following links:
All Tv and Tc datasets follow the format:
# Header: a line with three values: number of samples, network-input size, and network-output size
<number of samples> <network-input size> <network-output size>
# Samples: <number of samples> lines with <network-input size> values followed by <network-output size> values
<input 1> <input 2> ... <input <network-input size>> <output 1> <output 2> ... <output <network-output size>>
...
Where all Tv datasets have <network-input size> equal to 360 and <network-output size> equal 1, while all Tc datasets have <network-input size> equal to 80 and <network-output size> equal 1.
The previous links for the datasets refer to the pre-processed data (after shuffling and duplicates removal) as used in [1] to train, validate, and test the neural networks. The full velocity and AOC datasets in its raw format, the same dataset after each step of preprocessing, and the subsets obtained after the division in training, validation, and test datasets can be accessed in:
Velocity Datasets | Content |
---|---|
Tvfull Raw | The complete dataset in its raw format (without neither shuffle nor duplicates removal) |
Tvfull without duplicates | The complete dataset after duplicates removal |
Tvfull Index | A CSV file with three fields, the first is the sample position in the dataset Tvfull without duplicates, the second is the respective position of the sample in the shuffled dataset (used to create Tvtr,Tvva,Tvte), and the third is the respective position of the sample in the in the raw dataset Tvfull Raw. |
Tvfull shuffled | The complete dataset after shuffling |
Tvtr samples | The subset from the complete dataset used to train the neural network as used for the experiments in [1] |
Tvtr sorted | The training dataset in its original order |
Tvtr index | A CSV file with four fields: the first represents the sample number in the shuffled training set; the second is the respective position of the sample in the full dataset Tvfull after duplicates removal and shuffle; the third is the respective position of the sample in the full dataset Tvfull after duplicates removal; and the fourth is the sample position in the full dataset Tvfull before duplicates removal (Raw). |
Tvva samples | The subset from the complete dataset used to validate the neural network as used for the experiments in [1] |
Tvva sorted | The validation dataset in its original order |
Tvva index | A CSV file with four fields: the first represents the sample number in the shuffled validation set; the second is the respective position of the sample in the full dataset Tvfull after duplicates removal and shuffle; the third is the respective position of the sample in the full dataset Tvfull after duplicates removal; and the fourth is the sample position in the full dataset Tvfull before duplicates removal (Raw). |
Tvte samples | The subset from the complete dataset used to test the neural network as used for the experiments in [1] |
Tvte sorted | The test dataset in its original order |
Tvte index | A CSV file with four fields: the first represents the sample number in the shuffled test set; the second is the respective position of the sample in the full dataset Tvfull after duplicates removal and shuffle; the third is the respective position of the sample in the full dataset Tvfull after duplicates removal; and the fourth is the sample position in the full dataset Tvfull before duplicates removal (Raw). |
AOC Datasets | Content |
---|---|
Tcfull Raw | The complete dataset in its raw format (without neither shuffle nor duplicates removal) |
Tcfull without duplicates | The complete dataset after duplicates removal |
Tcfull shuffled Index | A CSV file with three fields, the first is the sample position in the dataset Tcfull without duplicates, the second is the respective position of the sample in the shuffled dataset (used to create Tctr,Tcva,Tcte), and the third is the respective position of the sample in the in the raw dataset Tcfull Raw. |
Tcfull shuffled | The complete dataset after shuffling |
Tctr samples | The subset from the complete dataset used to train the neural network as used for the experiments in [1] |
Tctr sorted | The training dataset in its original order |
Tctr index | A CSV file with four fields: the first represents the sample number in the shuffled training set; the second is the respective position of the sample in the full dataset Tcfull after duplicates removal and shuffle; the third is the respective position of the sample in the full dataset Tcfull after duplicates removal; and the fourth is the sample position in the full dataset Tcfull before duplicates removal (Raw). |
Tcva samples | The subset from the complete dataset used to validate the neural network as used for the experiments in [1] |
Tcva sorted | The validation dataset in its original order |
Tcva index | A CSV file with four fields: the first represents the sample number in the shuffled validation set; the second is the respective position of the sample in the full dataset Tcfull after duplicates removal and shuffle; the third is the respective position of the sample in the full dataset Tcfull after duplicates removal; and the fourth is the sample position in the full dataset Tcfull before duplicates removal (Raw). |
Tcte samples | The subset from the complete dataset used to test the neural network as used for the experiments in [1] |
Tcte sorted | The test dataset in its original order |
Tcte index | A CSV file with four fields: the first represents the sample number in the shuffled test set; the second is the respective position of the sample in the full dataset Tcfull after duplicates removal and shuffle; the third is the respective position of the sample in the full dataset Tcfull after duplicates removal; and the fourth is the sample position in the full dataset Tcfull before duplicates removal (Raw). |
To use the dgfann to find configurations of neural networks (NN) and train these NNs follow the steps below.
For running the genetic algorithm in a single machine to configure and train the Velocity neural network [1]:
- Go to the directory of the Velocity neural network:
cd dgfann_lcad/dgfann_velocity
- Set the parameters of this network in the file config.py (already set according to [1])
- Compile the Genetic Code (GC) C code:
make
- In RNAGenetico.py, make shure you have 'distribuido=False' in the line:
AG = AlgGenetico(tipoGenes, populacaoInicial, avaliacaoRNA, criterioSatisfacao,
considMaiorAvaliacao=False, maxGeracoes=maximoGeracoes, verboso=True, distribuido=False)
- Run GA with the command:
./RNAGenetico.py
- Copy the trained NNs of the last GA population (all, if the desired fitness was not achieved, or only those that achieved the desired fitness) to ../RNAs. The file names tell the configuration of each NN:
./utils/01-copiar_redes.sh
- The file names tell the configuration of each NN:
Ex.: 001-2_10_0_50_0_0.1_0.8_0.4_300.net means:
001: rank of the individual
2: number of hidden layers
10: hidden layer(s) activation function
0: output layer activation function
50: number of neurons in the hidden layer
0: learning algorithm
0.1: learning rate
0.8: momentum
0.4: learning rate decay
300: maximum epochs to train
For running the genetic algorithm in a cluster [1]:
- In the master node, go to the directory of the Velocity neural network:
cd dgfann_lcad/dgfann_velocity
- Set the parameters of this network in the file config.py (already set according to [1])
- Add the list of nodes at the end of the file config.py (or update this value if already exists):
nodes = ['192.168.36.78', '192.168.36.79', ...]
- Compile the Genetic Code (GC) C code:
make
- In RNAGenetico.py, make shure you have 'distribuido=True' in the line:
AG = AlgGenetico(tipoGenes, populacaoInicial, avaliacaoRNA, criterioSatisfacao,
considMaiorAvaliacao=False, maxGeracoes=maximoGeracoes, verboso=True, distribuido=True)
- Repeat the installation process for all other nodes.
- In each node, except the master node, run:
cd dgfann_lcad/dgfann_velocity
make
./dgfann_node.py
- In the master node, run GA with the command:
./RNAGenetico.py
- When the program running in the master node ends, stop all nodes processes and copy the folder 'Redes_Geradas' to master. Put all these folders in dgfann parent folder.
Ex.: parent_folder/
01-dgfann/Redes_Geradas
02-dgfann/Redes_Geradas
...
nn-dgfann/Redes_Geradas
- In the master node, copy the trained NNs of the last GA population (all, if the desired fitness was not achieved, or only those that achieved the desired fitness) to ../RNAs.
./utils/01-copiar_redes.sh
- The file names tell the configuration of each NN:
Ex.: 001-2_10_0_50_0_0.1_0.8_0.4_300.net means:
001: rank of the individual
2: number of hidden layers
10: hidden layer(s) activation function
0: output layer activation function
50: number of neurons in the hidden layer
0: learning algorithm
0.1: learning rate
0.8: momentum
0.4: learning rate decay
300: maximum epochs to train
To run the GA to find configurations of the AOC neural network and train the AOC neural network, repeat the same process using the 'dgfann_aoc' directory instead of the 'dgfann_velocity' directory.
- In the master node, run the Velocity neural networks with the test set (it is defined in the file 'config.py', variable 'nomeArqTeste'):
cd dgfann_lcad/dgfann_velocity
./utils/02-gen_plots.sh
# the plots will be placed in 'results_plots'
# the neural outputs will be placed in 'results_ann'
- To AOC neural network, run the same command, but in directory 'dfgann_aoc' instead of 'dgfann_velocity'.
The datasets used in [1] were collected at 2014/03/20 (velocity data) and 2014/03/24 (AOC data). Both, the velocity and AOC datasets, were shuffled, and split in training, validation, and test sets. Fig. 2, Fig. 3, and Fig. 4 show the training, validation, and test datasets for the velocity network, and Fig. 5, Fig. 6, and Fig. 8 show the training, validation, and test datasets for the AOC data. Although the datasets look quite similar, they represent independent samples extracted from the same datasets. The equality in the distribution of data over all datasets is explained by the fact that the data were first shuffled, and only then split.
Fig. 2. Training dataset for the velocity network, captured in 2014/03/20 |
Fig. 3. Validation dataset for the velocity network, captured in 2014/03/20 |
Fig. 4. Test dataset for the velocity network, captured in 2014/03/20 |
Fig. 5. Training dataset for the AOC network, captured in 2014/03/24 |
Fig. 6. Validation dataset for the AOC network, captured in 2014/03/24 |
Fig. 8. Test dataset for the AOC network, captured in 2014/03/24 |
Two additional datasets were collected for both, velocity and AOC, to evaluate the generalization level of the neural networks, and to analyze their behavior in new challenging scenarios. These new datasets were not presented to any neural network during the execution of the genetic algorithm nor during the training phase of the neural networks. They were used to evaluate the performance and the behavior of the neural network in response to previously unseen stimuli. The first dataset (dataset1: steering, dataset1: velocity) was captured in the same parking lot used in the experiments presented in [1], while the second dataset (dataset2: steering, dataset2: velocity) was captured in the beltway of the Universidade Federal do Espírito Santo (UFES). They were collected, respectively, at 2014/05/09 and 2014/08/02. The parking lot dataset size is similar to the datasets used in [1], with more smooth movements and less variability however. In the beltway dataset, the robotic car performed significantly different maneuvers in comparison with the parking lot datasets. These new maneuvers represent a constant challenge to the neural net estimation process, and in certain points took to the limit the network's extrapolation capacity. The beltway dataset is algo challeging due to its significantly higher size in relation to the training and validation datasets.
Fig. 9 (another view in Fig. 10) and Fig. 11 (another view in Fig. 12) show the velocity and AOC data, respectively, for the parking lot dataset along with the estimations made by the best neural network found in [1]. Fig. 13 (another view in Fig. 14) and Fig. 15 (another view in Fig. 16) show the same data for the beltway dataset. In the parking lot dataset, the neural net was able to successfully estimate the car’s velocity and AOC in the whole trajectory of the experiment. In the beltway dataset, on the other hand, the network produced satisfactory results for velocities as high as twice the ones seen in the training phase, but was unable to estimate values higher than that. Although the results demonstrated that the neural network was able to successfully generalize its knowledge to challenging unseen scenarios, the upper bound in the velocity estimations indicates that the neural net achieved its maximum extrapolation level. A neural network trained with additional high velocity data can attenuate the difference between the neural net predictions and the values measured by the car’s sensors. A new experiment with dgfann and a new train dataset is showed in next session.
Fig. 9. Velocity for 2014/05/09 plotted as [1] |
Fig. 10. Velocity for 2014/05/09 (alternative visualization) |
Fig. 9 and Fig.10 shows the neural network capacity to generalize the new dataset. With Mean Squared Error (MSE) of 4.1x10-3, this network has satisfactory results over the new parking lot dataset. Note that this dataset velocity is less than 3.5 m/s and the dataset used for [1] had values up to 4.5 m/s.
Fig. 11. AOC for 2014/05/09 plotted as [1] |
Fig. 12. AOC for 2014/05/09 (alternative visualization) |
Fig. 13. Velocity for 2014/08/02 plotted as [1] |
Fig. 14. Velocity for 2014/08/02 (alternative visualization) |
Fig. 15. AOC for 2014/08/02 plotted as [1] |
Fig. 16. AOC for 2014/08/02 (alternative visualization) |
The results of the new experiments can be accessed in the following links:
In the previous section, two new datasets have been presented to the neural network. But in beltway dataset, the neural network was unable to estimate the higher values (Fig. 13 and Fig. 14) without bias. Based on that, it was made an additional experiment to attenuate the difference between the neural net predictions and the values measured by the car's velocity sensors. In this experiment, the 2510 first samples from 2014/08/02 (they can be seen at Fig. 14) were concatenated in training dataset used in [1] (original dataset at Fig. 2 and this new dataset at Fig. 17) and the dgfann was executed again to find the neural network configuration.
Fig. 17. Train dataset for new experiment |
The neural network found at this time showed almost the same configuration as the neural network that was found at [1], the difference was the number of hidden neurons:
- First hidden layer: from 50 to 300;
- Second hidden layer: from 25 to 150;
As we have seen, the first neural network could not generalize the values because it didn't have the sufficient number of hidden neurons. This experiment also showed that the new training dataset (composed with the higher values) was sufficient to the dgfann finds the best neural network configuration.
This new neural network was able to successfully estimate the car velocity to all tests datasets, including the beltway dataset, resolving the problem mentioned in previous section. The results with the tests datasets applied to this new neural network are:
- The Fig. 18 (another view in Fig. 19) shows the test dataset used in [1]. These results can be compared with Fig. 4 and Fig. 5.
- The Fig. 20 (another view in Fig. 21) shows the test for the second parking lot dataset (2014/05/09). These results can be compared with Fig. 9 and Fig. 10.
- And the Fig. 22 (another view in Fig. 23) shows the test for the beltway dataset (2014/08/02). Please compare these results with Fig. 13 and Fig. 14, because these graphics show that the problem cited in previous section was solved.
Fig. 18. Paper's test dataset for new experiment |
Fig. 19. Paper's test dataset for new experiment (alternative visualization) |
Fig. 20. Second Parking lot dataset (2014/05/09) for new experiment |
Fig. 21. Second Parking lot dataset (2014/05/09) for new experiment (alternative visualization) |
Fig. 22. Beltway dataset for new experiment |
Fig. 23. Beltway dataset for new experiment (alternative visualization) |
[1] Alberto F. De Souza, Jacson Rodrigues Correia da Silva, Filipe Mutz, Claudine Badue, Thiago Oliveira-Santos, "Simulating Robotic Cars Using Multi-Layer Neural Networks", submitted to IJCNN'2016.