理论

灰度差分评价函数具有较好的计算性能,但其缺点也很明显,即在焦点附近灵敏度不高,即该函数在极值点附近过于平坦,从而导致聚焦精度难以提高。在文章《一种快速高灵敏度聚焦评价函数》中提出了一种新的评价函数,称之为灰度方差乘积法,即对每一个像素领域两个灰度差相乘后再逐个像素累加,该函数定义如下:
SMD2(灰度方差乘积) - 图1

代码

  1. def SMD2(img):
  2. '''
  3. :param img:narray 二维灰度图像
  4. :return: float 图像约清晰越大
  5. '''
  6. shape = np.shape(img)
  7. out = 0
  8. for x in range(0, shape[0]-1):
  9. for y in range(0, shape[1]-1):
  10. out+=math.fabs(int(img[x,y])-int(img[x+1,y]))*math.fabs(int(img[x,y]-int(img[x,y+1])))
  11. return out

https://blog.csdn.net/Greepex/article/details/90183018

5. SMD2 (灰度方差乘积)函数

灰度差分评价函数具有较好的计算性能,但其缺点也很明显,即在焦点附近灵敏度不高,即该函数在极值点附近过于平坦,从而导致聚焦精度难以提高。在文章《一种快速高灵敏度聚焦评价函数》中提出了一种新的评价函数,称之为灰度方差乘积法,即对每一个像素领域两个灰度差相乘后再逐个像素累加,该函数定义如下:
SMD2(灰度方差乘积) - 图2
代码:

  1. def SMD2(img):
  2. # 图像的预处理
  3. reImg = cv2.resize(img, (800, 900), interpolation=cv2.INTER_CUBIC)
  4. img2gray = cv2.cvtColor(reImg, cv2.COLOR_BGR2GRAY) # 将图片压缩为单通道的灰度图
  5. f=self._imageToMatrix(img2gray)/255.0
  6. x, y = f.shape
  7. D = 0
  8. for i in range(x - 1):
  9. for j in range(y - 1):
  10. D += np.abs(f[i+1,j]-f[i,j])*np.abs(f[i,j]-f[i,j+1])
  11. return D

https://gist.github.com/JuneoXIE/d595028586eec752f4352444fc062c44

  1. def _SMD2Detection(self, imgName):
  2. """
  3. 灰度方差乘积
  4. :param imgName:
  5. :return:
  6. """
  7. # step 1 图像的预处理
  8. img2gray, reImg = self.preImgOps(imgName)
  9. f=self._imageToMatrix(img2gray)/255.0
  10. x, y = f.shape
  11. score = 0
  12. for i in range(x - 1):
  13. for j in range(y - 1):
  14. score += np.abs(f[i+1,j]-f[i,j])*np.abs(f[i,j]-f[i,j+1])
  15. # strp3: 绘制图片并保存 不应该写在这里 抽象出来 这是共有的部分
  16. score=score
  17. newImg = self._drawImgFonts(reImg, str(score))
  18. newDir = self.strDir + "/_SMD2Detection_/"
  19. if not os.path.exists(newDir):
  20. os.makedirs(newDir)
  21. newPath = newDir + imgName
  22. cv2.imwrite(newPath, newImg) # 保存图片
  23. cv2.imshow(imgName, newImg)
  24. cv2.waitKey(0)
  25. return score

https://github.com/Leezhen2014/python—/blob/master/BlurDetection.py