This repo contains the code for the paper Federated mmWave Beam Selection Utilizing LIDAR Data avilable at: https://arxiv.org/abs/2102.02802
- Dr. Mahdi Boloursaz Mashhadi, Imperial College London, Email: m.boloursaz-mashhadi@imperial.ac.uk
- Mr. Mikolaj Jankowski, Imperial College London, Email: mikolaj.jankowski17@imperial.ac.uk
- Mr. Tze-Yang Tung, Imperial College London, Email: tze-yang.tung14@imperial.ac.uk
- Mr. Szymon Kobus, Imperial College London, Email: szymon.kobus17@imperial.ac.uk
- Prof. Deniz Gunduz, Imperial College London, Email: d.gunduz@imperial.ac.uk
In order to run our code, you need Python 3.7.9, Tensorflow 2.2.0, TFF 0.16.1 and Numpy. In order to install them, simply run:
$ pip install -r requirements.txt
Since our code usues GPU acceleration, having CUDA capable device would be highly recommended, along with CUDA toolkit v10.2.
If you prefer to use PyTorch, you can check our other repository: https://github.com/galidor/ITU_Beam_Selection.git
There are 4 Python files in this repo, requirements.txt, and this README file:
- models.py - definition of our model called Baseline2D.
- dataset.py - dataset preprocessing required by TF, along with our own preprocessing steps that transform 3D baseline data to 2D representations. Please note, even though we don't use the baseline features, it is not required to perform any preprocessing, as our code does it directly before the training/testing with a very small computational overhead.
- beam_train_model.py - code that is executed to perform full training of our network.
- beam_test_model.py - code that enables to test previously trained networks and generate .csv files with the predictions.
In this work we use Raymobtime2 dataset, which is a collection of realistic ray-tracing data obtained by simulating traffic in environment highly inspired by real world data. It utilizes SUMO for mobility simulations, Insite for ray-tracing, Cadmapper and Open Street Map for importing realistic outdoor scenarios. The dataset is divided into smaller sets, with different frequencies considered, various number of receivers, and environments. We trained our models on the s008 dataset (we combined both training and validation subsets) and validated on s009.
In order to train our network, you need to run the following command:
$ python beam_train_model.py --lidar_training_data <path to the LIDAR baseline training .npz file>
--beam_training_data <path to the baseline training beam .npz file>
--lidar_validation_data <path to the LIDAR baseline validation .npz file>
--beam_validation_data <path to the baseline validation beam .npz file>
--model_path <path, where your model will be stored>
Please note, that if the validation data are not provided, training data will be used as the validation set. If you provide multiple .npz files, they will be combined into larger dataset.
In order to evaluate pretrained model, simply run evaluate.py, as follows:
$ python beam_test_model.py --lidar_test_data <path to the LIDAR baseline test .npz file>
--beam_test_data <path to the baseline test beam .npz file>
--model_path <path, where your model is stored>
--preds_csv_path <path, where you want your .csv file with the predictions to be stored>
In order to evaluate our code in the federated learning setup, please run the following code:
$ python federated_beam.py
Please note, that all the training and validation .npz files have to be copied to the same folder as the code. We particularly use the following files:
- lidar_input_train.npz and lidar_input_validation.npz from Raymobtime s008
- beams_output_train.npz and beams_output_validation.npz from Raymobtime s008
- lidar_input_test.npz and beams_output_test.npz from Raymobtime s009
If you have any further questions related to this repo, feel free to contact us at {m.boloursaz-mashhadi, mikolaj.jankowski17}@imperial.ac.uk or raise an Issue within this repo. We will do our best to reply as soon as possible.
- M. B. Mashhadi, M. Jankowski, T. -Y. Tung, S. Kobus and D. Gündüz, "Federated mmWave Beam Selection Utilizing LIDAR Data," in IEEE Wireless Communications Letters, vol. 10, no. 10, pp. 2269-2273, Oct. 2021, doi: 10.1109/LWC.2021.3099136. Link: https://ieeexplore.ieee.org/document/9493715
- ITU AI/ML in 5G Challenge website: https://www.itu.int/en/ITU-T/AI/challenge/2020/Pages/default.aspx
- Raymobtime dataset: https://www.lasse.ufpa.br/raymobtime/
- A. Klautau, P. Batista, N. González-Prelcic, Y. Wang and R. W. Heath Jr., “5G MIMO Data for Machine Learning: Application to Beam-Selection using Deep Learning” in 2018 Information Theory and Applications Workshop (ITA).