Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/priyabagaria/Image-Blur-Detection
Classification of Blurred and Non-Blurred Images
https://github.com/priyabagaria/Image-Blur-Detection
image-processing
Last synced: 2 months ago
JSON representation
Classification of Blurred and Non-Blurred Images
- Host: GitHub
- URL: https://github.com/priyabagaria/Image-Blur-Detection
- Owner: priyabagaria
- License: gpl-3.0
- Created: 2018-06-24T07:08:56.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2021-12-08T07:21:38.000Z (about 3 years ago)
- Last Synced: 2024-08-01T15:30:11.814Z (5 months ago)
- Topics: image-processing
- Language: Python
- Homepage:
- Size: 24.4 KB
- Stars: 118
- Watchers: 7
- Forks: 28
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Image-Blur-Detection
Classification of Blurred and Non-Blurred Images**CERTH Image Blur Dataset**
> E. Mavridaki, V. Mezaris, "No-Reference blur assessment in natural images using Fourier transform and spatial pyramids", Proc. IEEE International Conference on Image Processing (ICIP 2014), Paris, France, October 2014.
The dataset consists of undistorted, naturally-blurred and artificially-blurred images for image quality
assessment purposes.
Download the dataset from here:
http://mklab.iti.gr/files/imageblur/CERTH_ImageBlurDataset.zipUnzip and load the files into a directory named **CERTH_ImageBlurDataset**
---
## Variation of the Laplacian
**Using OpenCV2**This method yielded an accuracy of **87.29%**
`cv2.Laplacian(img, cv2.CV_64F).var()`
The Laplacian Operator is applied on each of the images.
The variation of the result is calculated.
If the variation is below the threshold, 400 in this case, the image is classified as blurry.
Otherwise, it is classified as non-blurry.To run this model:
`python OpenCV_var.py`
---
## Convolutional Neural Network
To load and pickle train data and its labels:
`python load_traindata.py`
To load and pickle test data and its labels:
`python load_testdata.py`
A Convolutional Neural Network is trained which yields an accuracy of **67.70%** on the evaluation dataset.
The deep learning model has five layers.
This accuracy can further be improved by increasing the input dimensions of the first layer in the model and the number of epochs.
However, due to constraints related to computational power, I was unable to run the model.To train the CNN:
`python CNN.py`
---
## Maximum of Laplacian
**Using OpenCV2**An accuracy of **63.72%** is achieved using this method.
`gray = cv2.resize(cv2.imread(imagepath, cv2.IMREAD_GRAYSCALE), input_size)`
`numpy.max(cv2.convertScaleAbs(cv2.Laplacian(gray,3)))`
The result of the Laplacian Operator is converted to an absolute scale (0-255).
The max of the values is taken for each image.
The threshold is set at 215. Values lower than 215, classify the image as out-of-focus or blurry.
Greater than 215 is classified as non-blurred.To run this model:
`python OpenCV_max.py`