/HWMNet

Half Wavelet Attention on M-Net+ for Low-light Image Enhancement

Primary LanguagePythonApache License 2.0Apache-2.0

PWC

Chi-Mao Fan, Tsung-Jung Liu, Kuan-Hsien Liu

paper official_paper video slides poster Hugging Face Spaces Visitors

Abstract : Low-Light Image Enhancement is a compute vision task which reinforces the dark images to appropriate brightness. It can also be seen as an ill-posed problem in image restoration domain. With the success of deep neural networks, the convolutional neural networks surpass the traditional algorithm-based methods and become the mainstream in the computer vision area. To advance the performance of enhancement algorithms, we propose an image enhancement network (HWMNet) basing on an improved hierarchical architecture model: M-Net+. Specifically, we use a half wavelet attention block on M-Net+ to enrich the features of wavelet domain. Furthermore, our HWMNet has competitive performance results on two image enhancement datasets in terms of quantitative metrics and visual quality.

Network Architecture

HWMNet

Overall Framework of HWMNet

Half Wavelet Attention Block (HWAB)

Resizing Block (Pixel Shuffle)

Quick Run

You can simply demo on my space of Hugging Face

or test on local environment:

To test the pre-trained models of enhancing on your own images, run

python demo.py --input_dir images_folder_path --result_dir save_images_here --weights path_to_models

All pre-trained models can be downloaded at pretrained_model/README.md or here

Train

To train the restoration models of low-light enhancement. You should check the following components are correct:

  • training.yaml:

    # Training configuration
    GPU: [0,1,2,3]
    
    VERBOSE: False
    
    MODEL:
      MODE: 'HWMNet-96-LOL'
    
    # Optimization arguments.
    OPTIM:
      BATCH: 2
      EPOCHS: 100
      # EPOCH_DECAY: [10]
      LR_INITIAL: 2e-4
      LR_MIN: 1e-6
      # BETA1: 0.9
    
    TRAINING:
      VAL_AFTER_EVERY: 1
      RESUME: False
      TRAIN_PS: 256
      VAL_PS: 256
      TRAIN_DIR: './datasets/LOL/train'       # path to training data
      VAL_DIR: './datasets/LOL/test' # path to validation data
      SAVE_DIR: './checkpoints'           # path to save models and images
    
  • Dataset:
    The preparation of dataset in more detail, see datasets/README.md.

  • Train:
    If the above path and data are all correctly setting, just simply run:

    python train.py
    
  • Details of Hyperparameters

     -------------------------------------------------
     LOL dataset:
     Training patches: 4850 (485 x 10)
     Validation: 15
     Initial learning rate: 5e-5
     Final learning rate: 1e-5
     Training epochs: 300 (200 is enough)
    
     MIT-5K dataset:
     Training patches: 36000 (4500 x 8)
     Validation: 500
     Initial learning rate: 1e-4
     Final learning rate: 1e-6
     Training epochs: 100
     -------------------------------------------------
    

Test (Evaluation)

  • To test the PSNR, SSIM and LPIPS of image enhancement, see evaluation.py and run
python evaluation.py -dirA images_folder_path -dirB images_folder_path -type image_data_type --use_gpu use_gpu_or_not

Result

  • Evaluation on LOL dataset

  • Evaluation on MIT-Adobe FiveK dataset

Visual Comparison

  • Evaluation on LOL dataset

  • Evaluation on MIT-Adobe FiveK dataset

More visual results can be downloaded at here.

Citation

@inproceedings{fan2022half,
  title={Half wavelet attention on M-Net+ for low-light image enhancement},
  author={Fan, Chi-Mao and Liu, Tsung-Jung and Liu, Kuan-Hsien},
  booktitle={2022 IEEE International Conference on Image Processing (ICIP)},
  pages={3878--3882},
  year={2022},
  organization={IEEE}
}

Contact

If you have any question, feel free to contact qaz5517359@gmail.com