《LearnPython-Python学习笔记》-SMD2(灰度方差乘积)

admin 2025-11-07 01:25:37 编程 来源:ZONE.CI 全球网 0 阅读模式
  • 理论
  • 代码
  • 5. SMD2 (灰度方差乘积)函数

    理论

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

    以太坊cppgolang区别 编程

    以太坊cppgolang区别

    以太坊是一种去中心化的开源平台,它采用智能合约技术,旨在构建和运行不受干扰的分布式应用程序。作为目前最受欢迎的区块链平台之一,以太坊提供了多种编程语言的支持,其
    progolang 编程

    progolang

    Go语言(Golang)是由Google开发的一门静态类型编程语言。作为一名专业的Golang开发者,我深知这门语言的优势和特点。在本文中,我将介绍Golang
    golangn个发送者 编程

    golangn个发送者

    Golang是一种开源的编程语言,由Google团队开发,旨在提高程序的并发性和简化软件开发过程。在Go语言中,有时需要向多个接收者发送信息。本文将介绍如何在G
    golang技能图谱 编程

    golang技能图谱

    从互联网行业的快速发展到人工智能技术的日益成熟,各种编程语言也应运而生。而在这众多的编程语言中,Golang(即Go)作为一门强大且高效的开发语言备受关注。Go
    评论:0   参与:  6