文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python中图像点运算与灰度化处理的示例分析

2023-06-29 05:48

关注

这篇文章主要介绍了Python中图像点运算与灰度化处理的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

一.图像点运算概念

图像点运算(Point Operation)指对于一幅输入图像,将产生一幅输出图像,输出图像的每个像素点的灰度值由输入像素点决定。点运算实际上是灰度到灰度的映射过程,通过映射变换来达到增强或者减弱图像的灰度。还可以对图像进行求灰度直方图、线性变换、非线性变换以及图像骨架的提取。它与相邻的像素之间没有运算关系,是一种简单和有效的图像处理方法[1]。

图像的灰度变换可以通过有选择的突出图像感兴趣的特征或者抑制图像中不需要的特征,从而改善图像的质量,凸显图像的细节,提高图像的对比度。它也能有效地改变图像的直方图分布,使图像的像素值分布更为均匀[2-3]。它在实际中有很多的应用:

设输入图像为A(x,y),输出图像为B(x,y),则点运算可以表示为:

Python中图像点运算与灰度化处理的示例分析

图像点运算与几何运算存在差别,不会改变图像内像素点之间的空间位置关系。同时与局部(领域)运算也存在差别,输入像素和输出像素一一对应。

二.图像灰度化处理

图像灰度化是将一幅彩色图像转换为灰度化图像的过程。彩色图像通常包括R、G、B三个分量,分别显示出红绿蓝等各种颜色,灰度化就是使彩色图像的R、G、B三个分量相等的过程。灰度图像中每个像素仅具有一种样本颜色,其灰度是位于黑色与白色之间的多级色彩深度,灰度值大的像素点比较亮,反之比较暗,像素值最大为255(表示白色),像素值最小为0(表示黑色)。

假设某点的颜色由RGB(R,G,B)组成,常见灰度处理算法如表11-1所示:

Python中图像点运算与灰度化处理的示例分析

表11-1中Gray表示灰度处理之后的颜色,然后将原始RGB(R,G,B)颜色均匀地替换成新颜色RGB(Gray,Gray,Gray),从而将彩色图片转化为灰度图像。一种常见的方法是将RGB三个分量求和再取平均值,但更为准确的方法是设置不同的权重,将RGB分量按不同的比例进行灰度划分。比如人类的眼睛感官蓝色的敏感度最低,敏感最高的是绿色,因此将RGB按照0.299、0.587、0.144比例加权平均能得到较合理的灰度图像,如公式11-2所示[4-6]。

Python中图像点运算与灰度化处理的示例分析

在日常生活中,我们看到的大多数彩色图像都是RGB类型,但是在图像处理过程中,常常需要用到灰度图像、二值图像、HSV、HSI等颜色,OpenCV提供了cvtColor()函数实现这些功能。其函数原型如下所示:

dst = cv2.cvtColor(src, code[, dst[, dstCn]])

该函数的作用是将一个图像从一个颜色空间转换到另一个颜色空间,其中,RGB是指Red、Green和Blue,一副图像由这三个通道(channel)构成;Gray表示只有灰度值一个通道;HSV包含Hue(色调)、Saturation(饱和度)和Value(亮度)三个通道。

在OpenCV中,常见的颜色空间转换标识包括CV_BGR2BGRA、CV_RGB2GRAY、CV_GRAY2RGB、CV_BGR2HSV、CV_BGR2XYZ、CV_BGR2HLS等。下面是调用cvtColor()函数将图像进行灰度化处理的代码。

# -*- coding: utf-8 -*-# By:Eastmountimport cv2  import numpy as np  #读取原始图片src = cv2.imread('luo.png')#图像灰度化处理grayImage = cv2.cvtColor(src,cv2.COLOR_BGR2GRAY)#显示图像cv2.imshow("src", src)cv2.imshow("result", grayImage)#等待显示cv2.waitKey(0)cv2.destroyAllWindows()

输出结果如图11-1所示,左边是彩色的“小珞珞”原图,右边是将彩色图像进行灰度化处理之后的灰度图。其中,灰度图将一个像素点的三个颜色变量设置为相等(R=G=B),此时该值称为灰度值。

Python中图像点运算与灰度化处理的示例分析

同样,可以调用如下核心代码将彩色图像转换为HSV颜色空间,其输出结果如图11-2所示。

grayImage = cv2.cvtColor(src, cv2.COLOR_BGR2HSV)

Python中图像点运算与灰度化处理的示例分析

下面代码对比了九种常见的颜色空间,包括BGR、RGB、GRAY、HSV、YCrCb、HLS、XYZ、LAB和YUV,并循环显示处理后的图像。

# -*- coding: utf-8 -*-# By:Eastmountimport cv2  import numpy as np  import matplotlib.pyplot as plt#读取原始图像img_BGR = cv2.imread('luo.png')img_RGB = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2RGB)     #BGR转换为RGBimg_GRAY = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2GRAY)   #灰度化处理img_HSV = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2HSV)     #BGR转HSVimg_YCrCb = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2YCrCb) #BGR转YCrCbimg_HLS = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2HLS)     #BGR转HLSimg_XYZ = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2XYZ)     #BGR转XYZimg_LAB = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2LAB)     #BGR转LABimg_YUV = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2YUV)     #BGR转YUV#调用matplotlib显示处理结果titles = ['BGR', 'RGB', 'GRAY', 'HSV', 'YCrCb', 'HLS', 'XYZ', 'LAB', 'YUV']  images = [img_BGR, img_RGB, img_GRAY, img_HSV, img_YCrCb,          img_HLS, img_XYZ, img_LAB, img_YUV]  for i in range(9):     plt.subplot(3, 3, i+1), plt.imshow(images[i], 'gray')     plt.title(titles[i])     plt.xticks([]),plt.yticks([])  plt.show()

其运行结果如图11-3所示:

Python中图像点运算与灰度化处理的示例分析

三.基于像素操作的图像灰度化处理

前面讲述了调用OpenCV中cvtColor()函数实现图像灰度化的处理,接下来讲解基于像素操作的图像灰度化处理方法,主要是最大值灰度处理、平均灰度处理和加权平均灰度处理方法。

1.最大值灰度处理方法

该方法的灰度值等于彩色图像R、G、B三个分量中的最大值,公式如下:

Python中图像点运算与灰度化处理的示例分析

其方法灰度化处理后的灰度图亮度很高,实现代码如下。

# -*- coding: utf-8 -*-# By:Eastmountimport cv2  import numpy as np  import matplotlib.pyplot as plt#读取原始图像img = cv2.imread('luo.png')#获取图像高度和宽度height = img.shape[0]width = img.shape[1]#创建一幅图像grayimg = np.zeros((height, width, 3), np.uint8)#图像最大值灰度处理for i in range(height):    for j in range(width):        #获取图像R G B最大值        gray = max(img[i,j][0], img[i,j][1], img[i,j][2])        #灰度图像素赋值 gray=max(R,G,B)        grayimg[i,j] = np.uint8(gray)#显示图像cv2.imshow("src", img)cv2.imshow("gray", grayimg)#等待显示cv2.waitKey(0)cv2.destroyAllWindows()

其输出结果如图11-4所示,其处理效果的灰度偏亮。

Python中图像点运算与灰度化处理的示例分析

2.平均灰度处理方法

该方法的灰度值等于彩色图像R、G、B三个分量灰度值的求和平均值,其计算公式如公式(11-4)所示:

Python中图像点运算与灰度化处理的示例分析

平均灰度处理方法实现代码如下。

# -*- coding: utf-8 -*-# By:Eastmountimport cv2  import numpy as np  import matplotlib.pyplot as plt#读取原始图像img = cv2.imread('luo.png')#获取图像高度和宽度height = img.shape[0]width = img.shape[1]#创建一幅图像grayimg = np.zeros((height, width, 3), np.uint8)#图像平均灰度处理方法for i in range(height):    for j in range(width):        #灰度值为RGB三个分量的平均值        gray = (int(img[i,j][0]) + int(img[i,j][1]) + int(img[i,j][2]))  /  3        grayimg[i,j] = np.uint8(gray)#显示图像cv2.imshow("src", img)cv2.imshow("gray", grayimg)#等待显示cv2.waitKey(0)cv2.destroyAllWindows()

其输出结果如图11-5所示:

Python中图像点运算与灰度化处理的示例分析

3.加权平均灰度处理方法

该方法根据色彩重要性,将三个分量以不同的权值进行加权平均。由于人眼对绿色的敏感最高,对蓝色敏感最低,因此,按下式对RGB三分量进行加权平均能得到较合理的灰度图像。

Python中图像点运算与灰度化处理的示例分析

加权平均灰度处理方法实现代码如下所示:

# -*- coding: utf-8 -*-# By:Eastmountimport cv2  import numpy as np  import matplotlib.pyplot as plt#读取原始图像img = cv2.imread('luo.png')#获取图像高度和宽度height = img.shape[0]width = img.shape[1]#创建一幅图像grayimg = np.zeros((height, width, 3), np.uint8)#图像平均灰度处理方法for i in range(height):    for j in range(width):        #灰度加权平均法        gray = 0.30 * img[i,j][0] + 0.59 * img[i,j][1] + 0.11 * img[i,j][2]        grayimg[i,j] = np.uint8(gray)#显示图像cv2.imshow("src", img)cv2.imshow("gray", grayimg)#等待显示cv2.waitKey(0)cv2.destroyAllWindows()

其输出结果如图11-6所示:

Python中图像点运算与灰度化处理的示例分析

感谢你能够认真阅读完这篇文章,希望小编分享的“Python中图像点运算与灰度化处理的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯