原理简介
让图像的单一通道(大概灰度)和以下3 x 3的内核进行卷积
然后取相应的方差。
如果方差低于预先定义的阈值,则认为图像模糊;否则,图像不会模糊。
这种方法有效的原因是由于Laplacian算子本身的定义,它用于测量图像的二阶导数。
拉普拉斯算子突出显示图像中包含快速梯度变化的区域,很像Sobel和Scharr算子。和这些算子一样,Laplacian也经常用于边缘检测。
这里的假设是,如果一幅图像的方差较高,那么就说明图像有广泛的响应,包括类边和非类边,这是一幅正常的聚焦图像的代表。
但如果方差很低,那么就会有很小的响应扩散,这表明图像中几乎没有边缘。而图像越模糊,边缘就越少。所以可以用来检测是否模糊。
显然,这里的关键是设置正确的阈值,而阈值的设置与应用到的图像集相关。
如果阈值过低,你就会错误地将原本不模糊的图像标记为模糊。
如果阈值过高,那么实际上模糊的图像将不会被标记为模糊。这种方法只有在非常稳定的图像集(同一类型)中应用良好。
用法
示例代码,注意转换灰度图,但是我没转也没报错
import cv2 as cv image1 = cv.imread('imgs/tulips_1.jpg') image1 = cv.cvtColor(image1, cv.COLOR_BGR2GRAY) v1 = cv.Laplacian(image1, cv.CV_64F).var() image2 = cv.imread('imgs/melian.png') image2 = cv.cvtColor(image2, cv.COLOR_BGR2BGRA) v2 = cv.Laplacian(image2, cv.CV_64F).var() print(v1, v2) # 757.6573775277777 302.6699592172611
参考资料:
https://mp.weixin.qq.com/s/z8pob0V106fnjfJCLsTl3g 使用OpenCV进行模糊检测(拉普拉斯算子)