Sep. 28, 2024
Updates: Training scripts released.Sep. 20, 2024
News: Our paper PixMamba has been accepted by ACCV 2024.
Underwater Image Enhancement (UIE) is critical for marine research and exploration but hindered by complex color distortions and severe blurring. Recent deep learning-based methods have achieved remarkable results, yet these methods struggle with high computational costs and insufficient global modeling, resulting in locally under- or over- adjusted regions. We present PixMamba, a novel architecture, designed to overcome these challenges by leveraging State Space Models (SSMs) for efficient global dependency modeling. Unlike convolutional neural networks (CNNs) with limited receptive fields and transformer networks with high computational costs, PixMamba efficiently captures global contextual information while maintaining computational efficiency. Our dual-level strategy features the patch-level Efficient Mamba Net (EMNet) for reconstructing enhanced image feature and the pixel-level PixMamba Net (PixNet) to ensure fine-grained feature capturing and global consistency of enhanced image that were previously difficult to obtain. PixMamba achieves state-of-the-art performance across various underwater image datasets and delivers visually superior results.
conda create -n pixmamba python=3.10
# cuda and pytorch
conda install cuda-toolkit -c nvidia/label/cuda-11.8.0
# pytorch<=2.1 is required
conda install pytorch==2.1.2 torchvision==0.16.2 torchaudio==2.1.2 pytorch-cuda=11.8 -c pytorch -c nvidia
# dependencies
pip install -r requirements.txt
pip install opencv-python-headless ftfy regex
pip install mamba-ssm[causal-conv1d]
# mamba kernel
cd kernels/selective_scan && pip install . && cd ../.. # takes ~15 mins
# mmcv and mmagic (mmcv<=2.1.0 is required)
pip install mmcv==2.1.0 -f https://download.openmmlab.com/mmcv/dist/cu118/torch2.1/index.html
cd mmagic && pip install -r requirements.txt && pip install -e .
pip install gdown
gdown 1EL_4CgxO5pSKADqY2Glw2ZzV7A3VSaab
tar xfz data.tar.gz
-
UIEB
train
contains 800 image pairs. (u800)valid
contains 90 image pairs. (t90)test
contains 60 raw images for testing. (c60)valid_t90
contains 90 raw images for testing. (t90 w/o reference)
-
UCCS
blue
,green
, andblue-green
contains 100 images each.
pixmamba
└── data
├── uieb
│ ├── train
│ │ ├── raw-890
│ │ └── reference-890
│ ├── valid
│ │ ├── raw-890
│ │ └── reference-890
│ ├── test
│ └── valid_t90
└── uccs
├── blue
├── green
└── blue-green
export CONFIG_PATH=configs/pixmamba/final.py
export NUM_GPUS=1
cd mmagic
bash tools/dist_train.sh $CONFIG_PATH $NUM_GPUS # ~5hrs training on single RTX 4090 GPU
@article{lin2024pixmamba,
title={{PixMamba}: Leveraging State Space Models in a Dual-Level Architecture for Underwater Image Enhancement},
author={Wei-Tung Lin and Yong-Xiang Lin and Jyun-Wei Chen and Kai-Lung Hua},
journal={arXiv preprint arXiv:2406.08444},
year={2024}
}
This project is based on Mamba (paper, code), OpenMMLab, replknet, VMamba (paper, code), VM-UNet (paper, code), UIE_Benchmark (code). Thanks for their excellent works.
I'm happy to address any questions or concerns you may have. Please feel free to contact me at [email protected]