(c) Sharan Mourya, email: sharanmourya7@gmail.com
This repository holds the pytorch implementation of the original models described in the paper
Sharan Mourya, Pavan Reddy, Sai Dhiraj Amuru, "Spectral Temporal Graph Neural Network for massive MIMO CSI Prediction"
- Python >= 3.7
- PyTorch >= 1.7.1
- Scipy >= 1.5.4
- Numpy >= 1.19.5
- Pandas >= 1.1.5
We have provided the compressed channel matrices for Urban Macro (UMa) scenario with code word dimensions of 128 and 256 (512 is provided in the google folder shared here due to its large size). The channel matrices are according to the 3GPP 3-D channel model as specified in 38.901. These matrices are compressed using STNet and are stored in a .csv (for ex: UMa_128.csv) file for efficient access by the code. Original channel matrices are available at Folder. Decompressed channel matrices for various mobilities are available at Folder. However, you can generate your own compressed dataset by sending your channel matrices into the stnet.py file from the STNet repository (make sure to match the dimensions to 32x32x2).
Set the window size, horizon, dataset name, and other training parameters in main.py before running it. After training is finished, store the predicted channel matrices in a convenient location by defining the path in the handler.py file (lines 94-95). After training the GNN, import the saved dataset into STNet by running compare.py with appropriate file path (lines 442-443) to get the final decompressed channel matrices (note that you need to convert .csv to .pt before importing). Store them in a convenient location by changing lines 489-490.
Run spectral_eficiency.ipynb by importing the decompressed channel matrices obtained in the previous step. This step produces the spectral efficiency plots of STEM GNN for various mobilities.
In the shared Google Folder, there are also predicted channel matrices that are obtained after the training is performed on both STEM GNN and STNet. These predicted matrices can also be directly imported through the file spectral_eficiency.ipynb to obtain the spectral efficieny plots of STEM GNN.