This is the code for the paper "RadioDiff: An Effective Generative Diffusion Model for Sampling-Free Dynamic Radio Map Construction", IEEE TCCN.
- 2024-7: This repo is constructed.
- 2024-11: Our paper has been accepted by IEEE TCCN.
- 2024-12: The code has been released! 🎉🎉🎉
Abstract: Radio map (RM) is a promising technology that can obtain pathloss based on only location, which is significant for 6G network applications to reduce the communication costs for pathloss estimation. However, the construction of RM in traditional is either computationally intensive or depends on costly sampling-based pathloss measurements. Although the neural network (NN)-based method can efficiently construct the RM without sampling, its performance is still suboptimal. This is primarily due to the misalignment between the generative characteristics of the RM construction problem and the discrimination modeling exploited by existing NN-based methods. Thus, to enhance RM construction performance, in this paper, the sampling-free RM construction is modeled as a conditional generative problem, where a denoised diffusion-based method, named RadioDiff, is proposed to achieve high-quality RM construction. In addition, to enhance the diffusion model's capability of extracting features from dynamic environments, an attention U-Net with an adaptive fast Fourier transform module is employed as the backbone network to improve the dynamic environmental features extracting capability. Meanwhile, the decoupled diffusion model is utilized to further enhance the construction performance of RMs. Moreover, a comprehensive theoretical analysis of why the RM construction is a generative problem is provided for the first time, from both perspectives of data features and NN training methods. Experimental results show that the proposed RadioDiff achieves state-of-the-art performance in all three metrics of accuracy, structural similarity, and peak signal-to-noise ratio.
- install torch
conda create -n radiodiff python=3.9
conda avtivate radiodiff
pip install torch==1.12.1+cu113 torchvision==0.13.1+cu113 torchaudio==0.12.1 --extra-index-url https://download.pytorch.org/whl/cu113
- install other packages.
pip install -r requirement.txt
- prepare accelerate config.
accelerate config # HOW MANY GPUs YOU WANG TO USE.
We used the RadioMapSeer dataset for model training and testing.
- The data structure should look like:
|-- $RadioMapSeer
| |-- gain
| |-- |-- carsDPM
| |-- |-- |-- XXX_XX.PNG
| |-- |-- |-- XXX_XX.PNG
| ...
| |-- png
| |-- |-- buildings_complete
| |-- |-- |-- XXX_XX.PNG
| |-- |-- |-- XXX_XX.PNG
| ...
- train the first stage model (AutoEncoder):
accelerate launch train_vae.py --cfg ./configs/first_radio.yaml
- you should add the final model weight of the first stage to the config file
./configs/BSDS_train.yaml
(line 42), then train latent diffusion-edge model:
accelerate launch train_cond_ldm.py --cfg ./configs/radio_train.yaml
make sure your model weight path is added in the config file ./configs/radio_sample.yaml
(line 73), and run:
python sample_cond_ldm.py --cfg ./configs/radio_sample.yaml
Note that you can modify the sampling_timesteps
(line 11) to control the inference speed.
If you have some questions, please contact with [email protected].
Thanks to the base code DDM-Public.
@ARTICLE{radiodiff,
author={Wang, Xiucheng and Tao, Keda and Cheng, Nan and Yin, Zhisheng and Li, Zan and Zhang, Yuan and Shen, Xuemin},
journal={IEEE Transactions on Cognitive Communications and Networking},
title={RadioDiff: An Effective Generative Diffusion Model for Sampling-Free Dynamic Radio Map Construction},
year={2024},
pages={1-1},
keywords={Artificial neural networks;Training;Feature extraction;Diffusion models;Electromagnetics;Vehicle dynamics;Finite element analysis;Buildings;Noise;Costs;radio map;denoise diffusion model;generative problem;wireless network},
doi={10.1109/TCCN.2024.3504489}}