Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tuvovan/zero_dce_tf
Tensorflow Implementation of Zero_DCE - CVPR 2020
https://github.com/tuvovan/zero_dce_tf
low-light-image-enhancement tensorflow
Last synced: about 2 months ago
JSON representation
Tensorflow Implementation of Zero_DCE - CVPR 2020
- Host: GitHub
- URL: https://github.com/tuvovan/zero_dce_tf
- Owner: tuvovan
- License: mit
- Created: 2020-08-05T09:53:28.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-06-13T07:08:27.000Z (7 months ago)
- Last Synced: 2024-06-13T10:11:34.942Z (7 months ago)
- Topics: low-light-image-enhancement, tensorflow
- Language: Shell
- Homepage:
- Size: 26.1 MB
- Stars: 47
- Watchers: 3
- Forks: 19
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Zero-DCE TF
The Tensorflow Implementation of the [Zero-Reference Deep Curve Estimation for Low-Light Image Enhancement](https://openaccess.thecvf.com/content_CVPR_2020/papers/Guo_Zero-Reference_Deep_Curve_Estimation_for_Low-Light_Image_Enhancement_CVPR_2020_paper.pdf) - CVPR 2020## Update:
I pushed my project to Google Cloud Platform. May need more improvement. Should you have any comment or inquiries or just basically want to enhance your images, give it a try [here](http://34.64.150.58/)
## Content
- [Zero-DCE](#zero-dce-tf)
- [Getting Started](#getting-tarted)
- [Running](#running)
- [References](#references)
- [Citations](#citation)
- [Try Yourself](#try-on-web)## Getting Started
- Clone the repository
### Prerequisites
- Tensorflow 2.2.0+
- Python 3.6+
- Keras 2.3.0
- PIL
- numpy```python
pip install -r requirements.txt
```## Running
### Training
- Preprocess
- Download the training data at [Google Drive](https://drive.google.com/file/d/1HiLtYiyT9R7dR9DRTLRlUUrAicC4zzWN/view).- Run this file to generate data. (Please remember to change path first)
```
python src/prepare_data.py
```- Train ZERO_DCE
```
python train.py
```- Test ZERO_DCE
```
python test.py
```
## Usage
### Training
```
python train.py [-h] [--lowlight_images_path LOWLIGHT_IMAGES_PATH] [--lr LR]
[--num_epochs NUM_EPOCHS] [--train_batch_size TRAIN_BATCH_SIZE]
[--val_batch_size VAL_BATCH_SIZE] [--display_iter DISPLAY_ITER]
[--checkpoint_iter CHECKPOINT_ITER] [--checkpoints_folder CHECKPOINTS_FOLDER]
[--load_pretrain LOAD_PRETRAIN] [--pretrain_dir PRETRAIN_DIR]
``````
optional arguments: -h, --help show this help message and exit
--lowlight_images_path LOWLIGHT_IMAGES_PATH
--lr LR
--num_epochs NUM_EPOCHS
--train_batch_size TRAIN_BATCH_SIZE
--val_batch_size VAL_BATCH_SIZE
--display_iter DISPLAY_ITER
--checkpoint_iter CHECKPOINT_ITER
--checkpoints_folder CHECKPOINTS_FOLDER
--load_pretrain LOAD_PRETRAIN
--pretrain_dir PRETRAIN_DIR
```### Testing
```
python test.py [-h] [--lowlight_test_image_path]
```
```
optional arguments: -h, --help show this help message and exit
--lowlight_test_image_path LOWLIGHT_TEST_IMAGES_PATH
```### Video-DCE
Video-DCE is a simple adaptation of the lowlight image enhancement script to take videos as input, processing individual frames with the model, then outputing a HuffYUV encoded video while copying the existing audio track from the input video. Unlike the image processing scripts, Video-DCE will not resize the input video frames in order to process them. The output video will mimic the input's video FPS, but you can specify a different Display Aspect Ratio if needed.```
usage: video-dce.py [-h] --input_video INPUT_VIDEO [--output_video OUTPUT_VIDEO] [--max_frames MAX_FRAMES] [--dar DAR]
```
`MAX_FRAMES` can be useful for testing results out of a portion of the video. Frame counting will always start from zero.The script has only been tested with SD resolution videos (720x486, 640x480 and 720x480) as it's my main use case, so there might be bugs depending on the resolution of your input video.
#### Result
![INPUT](rs/1.bmp) | ![OUTPUT](rs/1_4_700.bmp) |
|:---:|:---:|
![INPUT](rs/2.bmp) | ![OUTPUT](rs/2_4_700.bmp) |
![INPUT](rs/3.bmp) | ![OUTPUT](rs/3_4_700.bmp) |
![INPUT](rs/4.bmp) | ![OUTPUT](rs/4_4_700.bmp) |
![INPUT](rs/5.bmp) | ![OUTPUT](rs/5_4_700.bmp) |
| input | output |## License
This project is licensed under the MIT License - see the [LICENSE](https://github.com/tuvovan/Zero_DCE_TF/blob/master/LICENSE) file for details
## References
[1] Zero-Reference Deep Curve Estimation for Low-Light Image Enhancement - CVPR 2020 [link](https://openaccess.thecvf.com/content_CVPR_2020/papers/Guo_Zero-Reference_Deep_Curve_Estimation_for_Low-Light_Image_Enhancement_CVPR_2020_paper.pdf)[3] Low-light dataset - [link](https://drive.google.com/file/d/1HiLtYiyT9R7dR9DRTLRlUUrAicC4zzWN/view)
## Citation
```
@misc{guo2020zeroreference,
title={Zero-Reference Deep Curve Estimation for Low-Light Image Enhancement},
author={Chunle Guo and Chongyi Li and Jichang Guo and Chen Change Loy and Junhui Hou and Sam Kwong and Runmin Cong},
year={2020},
eprint={2001.06826},
archivePrefix={arXiv},
primaryClass={cs.CV}
}
```## Try on web
The project is now available on GCP. [Give it a try](http://34.64.150.58/)
## Acknowledgments- This repo is the re-production of the original pytorch [version](https://github.com/Li-Chongyi/Zero-DCE)
- Thank you for helping me to understand more about pains that tensorflow may cause.
- Final words:
- Any ideas on updating or misunderstanding, please send me an email:
- If you find this repo helpful, kindly give me a star.