图像处理:图像清晰度评价

article/2025/8/28 9:10:04

目录

0、实现效果

1、概述

2、模糊度分类

1、运动模糊

2、压缩模糊

3、高斯模糊

3、清晰度量化指标

Brenner

能量梯度函数(Energy of Gradient)

           ​编辑

Roberts

Laplace

SMD(灰度方差)函数

SMD2 (灰度方差乘积)函数

4、图像清晰度评价实现

 5、总结与评价

参考资料:


0、实现效果

能够通过一张标准图,对同一组相机拍摄的照片进行清晰度评价。

1、概述

图像清晰度是用来指导调焦机构找到正焦位置的评价函数。理想的清晰度评价曲线类似于泊松分布,请看下图:

p点对应于正焦位置,P1 和P2 为正焦位置焦前和焦后采集到图像的清晰度评价结果。

正焦的图像比模糊的离焦图像边缘要更加的锐利清晰,相应的边缘像素灰度值变化大,因而会有更大的梯度值,从数学的角度来看图像,它是二维的离散矩阵,利用梯度函数可获取图像的灰度信息,来判别图像的清晰度,在离散信中梯度表现为差分形式。

2、模糊度分类

1、运动模糊

运动模糊是在捕获图像时,快门在打开时间内成像系统和拍摄 对象的短暂相对运动,造成成像在某个方向上形成的模糊。

2、压缩模糊

压缩模糊是图像在进行有损压缩丢失部分信息。

3、高斯模糊

高斯模糊是人为引入的一种模糊,使用高斯低通滤波器对原始图像进行滤波得到的。

3、清晰度量化指标

Brenner

Brenner梯度函数是最简单的梯度评价函数,它只是简单的计算相邻两个像素灰度差的平方,该函数定义如下:
                            D(f)=\sum_{y} \sum_{x}\left | f(x+2,y)-f(x,y)\right |^{2}

f(x,y) 表示图像f对应像素点(x,y)的灰度值,D(f)为图像清晰度计算结果。

python实现:

def brenner(img):''':param img:narray 二维灰度图像:return: int 图像越清晰越大'''shapes = np.shape(img)output = 0for x in range(0, shapes[0]-2):for y in range(0, shapes[1]):output+=(int(img[x+2,y])-int(img[x,y]))**2return output

能量梯度函数(Energy of Gradient)

将 x 方向和 y 方向的相邻像素的灰度值之差的平方和作为每个像素点的梯度值,对所有像素梯度值累加作为清晰度评价函数值,表达式如下所示:

           D(f)=\sum_{x} \sum_{y}\left \{[f(x+1,y)-f(x,y)]^{2}+[f(x,y+1)-f(x,y)]^{2}\right \}

python实现:

def EOG(img):''':param img:narray 二维灰度图像:return: int 图像越清晰越大'''shapes = np.shape(img)output = 0for x in range(0, shapes[0]-1):for y in range(0, shapes[1]-1):output+=((int(img[x+1,y])-int(img[x,y]))**2+(int(img[x,y+1])-int(img[x,y]))**2)return output

Roberts

Roberts函数与能量梯度函数相似,它是利用对角方向像素点灰度值之差。将4个相邻像素点的灰度值交叉相减的平方和作为每个像素点的梯度值,对所有像素梯度值累加作为清晰度评价函数值,表达式如下式所示:

          D(f)=\sum_{x} \sum_{y}\left \{[f(x+1,y+1)-f(x,y)]^{2}+[f(x+1,y)-f(x,y+1)]^{2}\right \}

 python实现:

def Roberts(img):''':param img:narray 二维灰度图像:return: int 图像越清晰越大'''shapes = np.shape(img)output = 0for x in range(0, shapes[0]-1):for y in range(0, shapes[1]-1):output+=((int(img[x+1,y+1])-int(img[x,y]))**2+(int(img[x+1,y])-int(img[x,y+1]))**2)return output

Laplace

采用Laplace算子与图像各个像素点的灰度值进行卷积得到一个梯度矩阵记为G(x,y),取各像素点梯度的平方和作为评价函数,如下式所示:

                                                 D(f)=\sum_{x} \sum_{y}\textit{G}^{2}(x,y)

                                        ​​​​​​​           \textit{G}(x,y)=f(x,y)\otimes L

                                                    L=\begin{bmatrix} 0& 1 & 1\\ 1 & -4&1 \\ 0 & 1& 0 \end{bmatrix}

 python实现:

def Laplacian(img):''':param img:narray 二维灰度图像:return: int 图像越清晰越大'''return cv2.Laplacian(img,cv2.CV_64F).var()

 由于之前推导过,你可以查看此文,这是我以前所写的一篇博客:(2条消息) 图像处理:边缘检测原理_夏天是冰红茶的博客-CSDN博客

SMD(灰度方差)函数

当完全聚焦时,图像最清晰,图像中的高频分量也最多,故可将灰度变化作为聚焦评价的依据,灰度方差法的公式如下:

                      D(f)=\sum_{y} \sum_{x}(\left |f(x,y)-f(x,y-1) \right |+\left |f(x+1,y)-f(x,y) \right |)

python实现:

def SMD(img):''':param img:narray 二维灰度图像:return: int 图像越清晰越大'''shape = np.shape(img)output = 0for x in range(1, shape[0]-1):for y in range(0, shape[1]):output+=math.fabs(int(img[x,y])-int(img[x,y-1]))output+=math.fabs(int(img[x,y]-int(img[x+1,y])))return output

SMD2 (灰度方差乘积)函数

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

                 D(f)=\sum_{y} \sum_{x}(\left |f(x,y)-f(x+1,y) \right |*\left |f(x,y)-f(x,y+1) \right |)

python实现:

def SMD2(img):''':param img:narray 二维灰度图像:return: int 图像约清晰越大'''shape = np.shape(img)output = 0for x in range(0, shape[0]-1):for y in range(0, shape[1]-1):output+=math.fabs(int(img[x,y])-int(img[x+1,y]))*math.fabs(int(img[x,y]-int(img[x,y+1])))return output

4、图像清晰度评价实现

SWD2:

import cv2
import pyps.pyzjr.definition as din
import pyps.pyzjr.utility as ultimage=ult.read_resize_image("./compare/8881.jpg",space=True)
img = din.SMD2(image)
print(img)cv2.putText(image, f"definition:{img:.2f}", (10, 30),cv2.FONT_HERSHEY_SIMPLEX, 0.8, (0, 0, 255), 3)
cv2.imshow("definition_Image", image)cv2.waitKey(0)

Brenner:

Laplacian:

 

 5、总结与评价

很遗憾,本次的清晰度评价失败了,如果想要得到一个边界值几乎不可能实现,哪怕通过大量图像数据(模糊图像与清晰图像)也不能完成,因为这些清晰度量化指标函数都是通过求图像像素的梯度,换汤不换药,在不同场景不同模糊的条件下很难去进行比对。

参考资料:

图像清晰度评价函数 - 知乎 (zhihu.com)

模糊图像检测-无参考图像的清晰度评价 - 知乎 (zhihu.com)

(2条消息) 无参考图像的清晰度评价方法_凌风探梅的博客-CSDN博客

(2条消息) 图像处理:边缘检测原理_夏天是冰红茶的博客-CSDN博客

(2条消息) 11种图像清晰度评价函数附MATLAB代码_姜饼8的博客-CSDN博客_能量梯度函数

图像处理评价指标之模糊度、清晰度(待更新) - 知乎 (zhihu.com)

一种快速高灵敏度聚焦评价函数 - 中国知网 (cnki.net)


http://chatgpt.dhexx.cn/article/XvKdFPVq.shtml

相关文章

图像清晰度评价函数

概述 图像清晰度是用来指导调焦机构找到正焦位置的评价函数。理想的清晰度评价曲线如下图所示,其中P 是评价函数最大值的位置,其对应正焦位置,P1 和P2 为正焦位置焦前和焦后采集到图像的清晰度评价结果。 为了指导调焦机构找到正焦位置,清晰度曲线须具有以下特点: 单…

计算图像清晰度

1、方差 在相机拍照时,通常会看到相机由模糊至清晰的自动对焦过程,逐渐形成清晰度比较高的图像。其实这是非常简单的处理,,并不需要非常特殊的算法,方法各式各样好多种,而且效率极其高。 表示样品离散程度的知识&…

一次搞懂清晰度、对比度以及锐化的区别

大字体 收藏 微博 http://tech.sina.com.cn/digi/dc/q/2017-11-29/doc-ifypceiq5781193.shtml   清晰度、对比度和锐化程度的调整,是照片后期的三个重要步骤。它们容易混淆,但各自效果却并不相同。本文会帮大家从原理上理清他们的区别。 1、对比度 对比…

手机通过笔记本上网~

如今的一般的智能机都有WIFI功能了,在这里哪大家分享手机如何利用笔记本上网,win7系统笔记本做无线路由器(无需软件) 工具/原料 一根网线 一台Windows7系统的笔记本电脑(或有外置无线网卡的台式机) 确保笔记…

计算机怎么连接手机网络,电脑怎么连接手机的热点上网?

我们使用电脑的时候,大部分时间需要连接网络。然而,断网的时候,是不是比找不到妈妈还着急,尤其是在看剧的时候,当然还有上传或下载文件的时候,哈哈哈~ 今天,我就教大家一个非常实用的方法&#…

计算机如何通过手机连接网络,主编教您手机怎么通过usb连接电脑上网

手机如何通过数据线连接电脑上网,相信很多人热切关注的问题,虽然比起以前我们又多了4G网,但比起无线网,手机数据还是要慢很多,但也是不时之需了,需要上网的时候,那手机怎么通过usb连接电脑上网&…

手机用USB连接电脑宽带上网(只需轻松3步即可上网)

想用手机上网,身边又没WIFI。手机又没流量。(主要就是体验一些电脑下载不了的任务) 如下载主题和设备调试什么的。 步骤很简单,只需要两步。所需要的软件工具如下: 电脑软件1.小米USB驱动(Win7的系统自动会…

计算机上网络怎么连接,手机怎么连接电脑上网

我们现在上网越来越方便了,无论是移动还是联通的无线网络都已经覆盖了很多的地区,我们的电脑可以随时随地的进行上网。当我们的电脑已经连接网路的时候我们我们手机是否可以通过电脑的网络进行上网而不用再次进行登录呢?答案是肯定的,一旦我…

电脑给手机开热点后,手机可以上网,但是电脑却不能上网了

这个问题困惑了我好久,也不知道为啥我手机就是连不上公司的网,然后只能电脑开热点了,发现开热点之后我电脑又不能上网了,让人头大啊,网上百度找到了解决方法。 (1)打开电脑的设置 (…

台式计算机网络共享,教大家怎么把电脑网络共享给手机上网

近日有关于怎么把电脑网络共享给手机上网的问题受到了很多网友们的关注,大多数网友都想要知道怎么把电脑网络共享给手机上网的具体情况,那么关于到怎么把电脑网络共享给手机上网的相关信息,小编也是在网上进行了一系列的信息,那么…

把计算机怎么连接手机的网络助手在哪里,手机如何连接电脑上网

手机如何连接电脑上网呢?虽然现在的智能手机普遍,手机上网也成了一件很普通的事,但是有时候头疼的是流量用完了,建议你利用笔记本来分享wifi,具体如何操作呢?其实很好设置,下面就教你手机连接电脑上网吧! 现在的笔记…

电脑和手机连接同一个无线,电脑不能上网,手机能上网?

目录 1.网络连接问题 2.解决办法就是: A.winr输入control打开控制面板打开网络和共享中心 B.更改适配器设置 C.找到连接的WLAN,鼠标右击选择属性 1.网络连接问题 今天晚上在用电脑连接家里的WIFI时,发现不能上网了,但是手机连接…

把计算机怎么连接手机的网络助手在哪里,手机连接电脑上网,详细教您手机如何连接电脑上网...

无线个人网是在小范围内相互连接数个装置所形成的无线网络,通常是个人可及的范围内。现在智能手机普遍,手机无线连接上网也成了一件很普通的事。但是依然还是有人不知道如何连接上网。那么,手机无线连接电脑上网怎么搞?下面,小编…

Android usb网卡配置ip地址,安卓手机通过电脑USB上网设置教程

安卓手机通过电脑USB上网设置教程 我这里总结了几种方法供大家参考。 方法一:usb连接线,手机有线上网 1、将手机通过usb线连接到电脑,勾选“设置 -> 无线和网络 -> 绑定与便携热点 -> USB绑定”选项,电脑上会出现虚拟网卡&#xff0…

这么连接计算机网络,详细教您手机怎么连接电脑上网

在使用电脑的过程中,我们经常使用手机连接电脑传送文件。那你们知道手机怎么连接电脑上网吗?小编问了很多人,果然都不知道。嘿嘿,今天小编就教你们一招,赶紧来学习一下吧 说到手机大家都不陌生,现在几乎人手…

计算机与手机联网,电脑怎么通过手机共享上网(两种手机和电脑连接上网方法)...

电脑也可以连接上手机,通过手机移动高速网络上网吗?没错,电脑和手机相互绑定上网是安卓手机的一个内置的功能,虽然大多情况下并不实用(手机流量套餐太贵了),但是对于某些人可能会很有用的,比如要办公编辑一…

计算机用手机的网络,台式电脑如何使用手机网络上网

当今社会网络已经成为大家生活、工作必不可少的重要一部分了,而最近有很多小伙伴问小编台式电脑如何使用手机网络上网,其实很简单,下面就由学习啦小编跟大家分享具体的方法吧,希望对大家有所帮助~ 台式电脑使用手机网络上网的方法…

通过USB设置手机连接电脑上网

将手机网络通过USB数据线共享给电脑上网, 将手机通过数据线连接到电脑。 电脑自动识别并且连接手机,手机端提示连接成功。 打开手机端的设置 点击下图中的“更多”选项。 选择“网络共享与便携式热点” 打开下图中的开关按钮。 在看看电脑是…

电脑通过android手机上网

话说没网络怎么能行啊,要是断网了怎么办,用android手机可以轻松上网,缺点就是太费流量了,没有包月的大侠就不要用了,刷个网页一刀就没了,真是坑爹;下面来说说怎么上吧,装个PdaNet几分…

电脑通过android手机上网 .

方案一 转自:http://blog.csdn.net/lastsweetop/article/details/7257546 话说没网络怎么能行啊,要是断网了怎么办,用android手机可以轻松上网,缺点就是太费流量了,没有包月的大侠就不要用了,刷个网页一刀…