This repository is for Frequency Attention Network(FAN) introduced in the following paper
Frequency Attention Network: Blind Noise Removal for Real Images, ACCV, 2020
The checkpoint files can be downloaded here. Checkpoint The extracted code is ev3w.
- Python 3.6, torch 1.1.0
- More details(see requirements.txt)
With outstanding feature extraction capabilities, deep convolutional neural networks(CNNs) have achieved extraordinary improvements in image denoising tasks. However, because of the difference of statistical characteristics of signal-dependent noise and signal-independent noise, it is hard to model real noise for training and blind real image denoising is still an important challenge problem. In this work we propose a method for blind image denoising that combines frequency domain analysis and attention mechanism, named frequency attention network(FAN). We adopt wavelet transform to convert images from spatial domain to frequency domain with more sparse features to utilize spectral information and structure information. For the denoising task, the objective of the neural network is to estimate the optimal solution of the wavelet coeffcients of the clean image by nonlinear characteristics, which makes FAN possess good interpretability. Meanwhile, spatial and channel mechanisms are employed to enhance feature maps at different scales for capturing contextual information. Extensive experiments on the synthetic noise dataset and two real-world noise benchmarks indicate the superiority of our method over other competing methods at different noise type cases in blind image denoising.
Our proposed method FAN contains two subnetwork -- Est-Net and De-Net. Est-Net is to estimate the noise level map which plays the role of guidance. De-Net is for image denoising.
The SCAB combines the spatial attention mechanism and channel attention mechanism. The spatial mechanism can reweight the feature maps based on the position of different feature maps while the channel mechanism can focus on different types of features.
Test on the LIVE1 dataset with the addiative gaussian white noise of sigma = 50.
One example of test on SIDD dataset.
One example of test on DND dataset.
python test_awgn.py --ckpt[trained model] --img_dir[dataset directory] --sigma[sigma] --gpu[GPU or CPU]
python test_real_noise.py --ckpt[trained model] --img_dir[dataset directory] --is_gt[whether to compare ground truth(please set False when test the DND dataset)] --gpu[GPU or CPU]