opencv计算图像模糊度(sobel和laplacian)

2023-10-30 03:40

本文主要是介绍opencv计算图像模糊度(sobel和laplacian),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

# -*-coding=UTF-8-*-
"""
在无参考图下,检测图片质量的方法
"""
import os
import cv2import numpy as np
from skimage import filtersclass BlurDetection:def __init__(self, strDir):print("图片检测对象已经创建...")self.strDir = strDirdef _getAllImg(self, strType='jpg'):"""根据目录读取所有的图片:param strType: 图片的类型:return:  图片列表"""names = []for root, dirs, files in os.walk(self.strDir):  # 此处有bug  如果调试的数据还放在这里,将会递归的遍历所有文件for file in files:# if os.path.splitext(file)[1]=='jpg':names.append(str(file))return namesdef _imageToMatrix(self, image):"""根据名称读取图片对象转化矩阵:param strName::return: 返回矩阵"""imgMat = np.matrix(image)return imgMatdef _blurDetection(self, imgName):# step 1 图像的预处理img2gray, reImg = self.preImgOps(imgName)imgMat=self._imageToMatrix(img2gray)/255.0x, y = imgMat.shapescore = 0for i in range(x - 2):for j in range(y - 2):score += (imgMat[i + 2, j] - imgMat[i, j]) ** 2# step3: 绘制图片并保存  不应该写在这里  抽象出来   这是共有的部分score=score/10newImg = self._drawImgFonts(reImg, str(score))newDir = self.strDir + "/_blurDetection_/"if not os.path.exists(newDir):os.makedirs(newDir)newPath = newDir + imgNamecv2.imwrite(newPath, newImg)  # 保存图片cv2.imshow(imgName, newImg)cv2.waitKey(0)return scoredef _SMDDetection(self, imgName):# step 1 图像的预处理img2gray, reImg = self.preImgOps(imgName)f=self._imageToMatrix(img2gray)/255.0x, y = f.shapescore = 0for i in range(x - 1):for j in range(y - 1):score += np.abs(f[i+1,j]-f[i,j])+np.abs(f[i,j]-f[i+1,j])# strp3: 绘制图片并保存  不应该写在这里  抽象出来   这是共有的部分score=score/100newImg = self._drawImgFonts(reImg, str(score))newDir = self.strDir + "/_SMDDetection_/"if not os.path.exists(newDir):os.makedirs(newDir)newPath = newDir + imgNamecv2.imwrite(newPath, newImg)  # 保存图片cv2.imshow(imgName, newImg)cv2.waitKey(0)return scoredef _SMD2Detection(self, imgName):"""灰度方差乘积:param imgName::return:"""# step 1 图像的预处理img2gray, reImg = self.preImgOps(imgName)f=self._imageToMatrix(img2gray)/255.0x, y = f.shapescore = 0for i in range(x - 1):for j in range(y - 1):score += np.abs(f[i+1,j]-f[i,j])*np.abs(f[i,j]-f[i,j+1])# strp3: 绘制图片并保存  不应该写在这里  抽象出来   这是共有的部分score=scorenewImg = self._drawImgFonts(reImg, str(score))newDir = self.strDir + "/_SMD2Detection_/"if not os.path.exists(newDir):os.makedirs(newDir)newPath = newDir + imgNamecv2.imwrite(newPath, newImg)  # 保存图片cv2.imshow(imgName, newImg)cv2.waitKey(0)return scoredef _Variance(self, imgName):"""灰度方差乘积:param imgName::return:"""# step 1 图像的预处理img2gray, reImg = self.preImgOps(imgName)f = self._imageToMatrix(img2gray)# strp3: 绘制图片并保存  不应该写在这里  抽象出来   这是共有的部分score = np.var(f)newImg = self._drawImgFonts(reImg, str(score))newDir = self.strDir + "/_Variance_/"if not os.path.exists(newDir):os.makedirs(newDir)newPath = newDir + imgNamecv2.imwrite(newPath, newImg)  # 保存图片cv2.imshow(imgName, newImg)cv2.waitKey(0)return scoredef _Vollath(self,imgName):"""灰度方差乘积:param imgName::return:"""# step 1 图像的预处理img2gray, reImg = self.preImgOps(imgName)f = self._imageToMatrix(img2gray)source=0x,y=f.shapefor i in range(x-1):for j in range(y):source+=f[i,j]*f[i+1,j]source=source-x*y*np.mean(f)# strp3: 绘制图片并保存  不应该写在这里  抽象出来   这是共有的部分newImg = self._drawImgFonts(reImg, str(source))newDir = self.strDir + "/_Vollath_/"if not os.path.exists(newDir):os.makedirs(newDir)newPath = newDir + imgNamecv2.imwrite(newPath, newImg)  # 保存图片cv2.imshow(imgName, newImg)cv2.waitKey(0)return sourcedef _Tenengrad(self,imgName):"""灰度方差乘积:param imgName::return:"""# step 1 图像的预处理img2gray, reImg = self.preImgOps(imgName)f = self._imageToMatrix(img2gray)tmp = filters.sobel(f)source=np.sum(tmp**2)source=np.sqrt(source)# strp3: 绘制图片并保存  不应该写在这里  抽象出来   这是共有的部分newImg = self._drawImgFonts(reImg, str(source))newDir = self.strDir + "/_Tenengrad_/"if not os.path.exists(newDir):os.makedirs(newDir)newPath = newDir + imgNamecv2.imwrite(newPath, newImg)  # 保存图片cv2.imshow(imgName, newImg)cv2.waitKey(0)return sourcedef Test_Tenengrad(self):imgList = self._getAllImg(self.strDir)for i in range(len(imgList)):score = self._Tenengrad(imgList[i])print(str(imgList[i]) + " is " + str(score))def Test_Vollath(self):imgList = self._getAllImg(self.strDir)for i in range(len(imgList)):score = self._Variance(imgList[i])print(str(imgList[i]) + " is " + str(score))def TestVariance(self):imgList = self._getAllImg(self.strDir)for i in range(len(imgList)):score = self._Variance(imgList[i])print(str(imgList[i]) + " is " + str(score))def TestSMD2(self):imgList = self._getAllImg(self.strDir)for i in range(len(imgList)):score = self._SMD2Detection(imgList[i])print(str(imgList[i]) + " is " + str(score))returndef TestSMD(self):imgList = self._getAllImg(self.strDir)for i in range(len(imgList)):score = self._SMDDetection(imgList[i])print(str(imgList[i]) + " is " + str(score))returndef TestBrener(self):imgList = self._getAllImg(self.strDir)for i in range(len(imgList)):score = self._blurDetection(imgList[i])print(str(imgList[i]) + " is " + str(score))returndef preImgOps(self, imgName):"""图像的预处理操作:param imgName: 图像的而明朝:return: 灰度化和resize之后的图片对象"""strPath = self.strDir + imgNameimg = cv2.imread(strPath)  # 读取图片cv2.moveWindow("", 1000, 100)# cv2.imshow("原始图", img)# 预处理操作reImg = cv2.resize(img, (800, 900), interpolation=cv2.INTER_CUBIC)  #img2gray = cv2.cvtColor(reImg, cv2.COLOR_BGR2GRAY)  # 将图片压缩为单通道的灰度图return img2gray, reImgdef _drawImgFonts(self, img, strContent):"""绘制图像:param img: cv下的图片对象:param strContent: 书写的图片内容:return:"""font = cv2.FONT_HERSHEY_SIMPLEXfontSize = 5# 照片 添加的文字    /左上角坐标   字体   字体大小   颜色        字体粗细cv2.putText(img, strContent, (0, 200), font, fontSize, (0, 255, 0), 6)return imgdef _lapulaseDetection(self, imgName):""":param strdir: 文件所在的目录:param name: 文件名称:return: 检测模糊后的分数"""# step1: 预处理img2gray, reImg = self.preImgOps(imgName)# step2: laplacian算子 获取评分resLap = cv2.Laplacian(img2gray, cv2.CV_64F)score = resLap.var()print("Laplacian %s score of given image is %s", str(score))# strp3: 绘制图片并保存  不应该写在这里  抽象出来   这是共有的部分newImg = self._drawImgFonts(reImg, str(score))newDir = self.strDir + "/_lapulaseDetection_/"if not os.path.exists(newDir):os.makedirs(newDir)newPath = newDir + imgName# 显示cv2.imwrite(newPath, newImg)  # 保存图片cv2.imshow(imgName, newImg)cv2.waitKey(0)# step3: 返回分数return scoredef TestDect(self):names = self._getAllImg()for i in range(len(names)):score = self._lapulaseDetection(names[i])print(str(names[i]) + " is " + str(score))returnif __name__ == "__main__":BlurDetection = BlurDetection(strDir="D:/document/ZKBH/bug/face/")BlurDetection.Test_Tenengrad () # TestSMD

来源 https://github.com/Leezhen2014/python--/blob/master/BlurDetection.py

图像的模糊检测方法 - 修雨轩陈 - 博客园

在widerface数据集上测试, Test_Tenengrad的阈值选择为7能够得到一个较好的模糊度分类效果

不明白为什么要把图像resize到(800, 900)的尺度上再求梯度:

reImg = cv2.resize(img, (800, 900), interpolation=cv2.INTER_CUBIC)  #

关于各种算子介绍的文章:

Roberts算子、Sobel算子和Laplacian算子的数学推导 | 致永远-For Aye

从实验结果上比对来看,sobel比laplacian更稳定一些,所以在工程上决定用sobel。

********************

个人公众号“AI技术评论”,欢迎关注

                                          

 

这篇关于opencv计算图像模糊度(sobel和laplacian)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/305374

相关文章

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

使用Python开发一个图像标注与OCR识别工具

《使用Python开发一个图像标注与OCR识别工具》:本文主要介绍一个使用Python开发的工具,允许用户在图像上进行矩形标注,使用OCR对标注区域进行文本识别,并将结果保存为Excel文件,感兴... 目录项目简介1. 图像加载与显示2. 矩形标注3. OCR识别4. 标注的保存与加载5. 裁剪与重置图像

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

基于WinForm+Halcon实现图像缩放与交互功能

《基于WinForm+Halcon实现图像缩放与交互功能》本文主要讲述在WinForm中结合Halcon实现图像缩放、平移及实时显示灰度值等交互功能,包括初始化窗口的不同方式,以及通过特定事件添加相应... 目录前言初始化窗口添加图像缩放功能添加图像平移功能添加实时显示灰度值功能示例代码总结最后前言本文将

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

opencv实现像素统计的示例代码

《opencv实现像素统计的示例代码》本文介绍了OpenCV中统计图像像素信息的常用方法和函数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 统计像素值的基本信息2. 统计像素值的直方图3. 统计像素值的总和4. 统计非零像素的数量

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境