该系列文章是讲解Python OpenCV图像处理知识,前期主要讲解图像入门、OpenCV基础用法,中期讲解图像处理的各种算法,包括图像锐化算子、图像增强技术、图像分割等,后期结合深度学习研究图像识别、图像分类、目标检测应用。
前一篇文章介绍OpenCV实现图像形态学变换,包括图像顶帽运算和图像黑帽运算。本篇文章主要讲解灰度直方图的基本概念,Python调用OpenCV实现绘制图像直方图,基础性知识希望对您有所帮助。
-
一.灰度直方图基本概率
-
二.绘制直方图
-
三.使用OpenCV统计绘制直方图
-
四.总结
前文回顾(下面的超链接可以点击喔):
-
[Python图像处理] 二.OpenCV+Numpy库读取与修改像素
-
[Python图像处理] 十一.灰度直方图概念及OpenCV绘制直方图
学Python近八年,认识了很多大佬和朋友,感恩。深知自己很菜,得拼命努力前行,编程也没有什么捷径,干就对了。希望未来能更透彻学习和撰写文章,同时非常感谢参考文献中的大佬们的文章和分享,共勉。
- https://blog.csdn.net/eastmount
一. 灰度直方图基本概念
对于连续图像,平滑地从中心的高灰度级变化到边缘的低灰度级。直方图定义为:
二. 绘制直方图
绘制的直方图如下所示:
如果灰度级为0-255(最小值0黑色,最大值255白色),同样可以绘制对应的直方图,下图是三张图片拼接而成及其对应的直方图。
import matplotlib.pyplot as plt
hist(数据源, 像素级)
参数:
数据源必须是一维数组,通常需要通过函数ravel()拉直图像
像素级一般是256,表示[0, 255]
#encoding:utf-8
import cv2
import numpy as np
import matplotlib.pyplot as plt
src = cv2.imread('test01.jpg')
cv2.imshow("src", src)
cv2.waitKey(0)
cv2.destroyAllWindows()
plt.hist(src.ravel(), 256)
plt.show()
![[Python图像处理] 十一.灰度直方图概念及OpenCV绘制直方图 [Python图像处理] 十一.灰度直方图概念及OpenCV绘制直方图](https://cn-sec.com/wp-content/uploads/2022/05/2-1652196992.png)
三. 使用OpenCV统计绘制直方图
-
hist表示直方图,返回的是一个二维数组
-
images表示原始图像
-
channels表示指定通道,通道编号需要用中括号括起,输入图像是灰度图像时,它的值为[0],彩色图像则为[0]、[1]、[2],分别表示B、G、R
-
mask表示掩码图像,统计整副图像的直方图,设为None,统计图像的某一部分直方图时,需要掩码图像
-
histSize表示BINS的数量,参数子集的数目,如下图当bins=3表示三个灰度级
![[Python图像处理] 十一.灰度直方图概念及OpenCV绘制直方图 [Python图像处理] 十一.灰度直方图概念及OpenCV绘制直方图](https://cn-sec.com/wp-content/uploads/2022/05/6-1652196998.png)
-
ranges表示像素值范围,例如[0, 255]
-
accumulate表示累计叠加标识,默认为false,如果被设置为true,则直方图在开始分配时不会被清零,该参数允许从多个对象中计算单个直方图,或者用于实时更新直方图;多个直方图的累积结果用于对一组图像的直方图计算
#encoding:utf-8
import cv2
import numpy as np
import matplotlib.pyplot as plt
src = cv2.imread('test01.jpg')
#参数:原图像 通道[0]-B 掩码 BINS为256 像素范围0-255
hist = cv2.calcHist([src], [0], None, [256], [0,255])
print(type(hist))
print(hist.size)
print(hist.shape)
print(hist)
#encoding:utf-8
import cv2
import numpy as np
import matplotlib.pyplot as plt
#绘制sin函数曲线
x1 = np.arange(0, 6, 0.1)
y1 = np.sin(x1)
plt.plot(x1, y1)
#绘制坐标点折现
x2 = [0, 1, 2, 3, 4, 5, 6]
y2 = [0.3, 0.4, 2.5, 3.4, 4, 5.8, 7.2]
plt.plot(x2, y2)
#省略有规则递增的x2参数
y3 = [0, 0.5, 1.5, 2.4, 4.6, 8]
plt.plot(y3, color="r")
plt.show()
#encoding:utf-8
import cv2
import numpy as np
import matplotlib.pyplot as plt
src = cv2.imread('test01.jpg')
histb = cv2.calcHist([src], [0], None, [256], [0,255])
histg = cv2.calcHist([src], [1], None, [256], [0,255])
histr = cv2.calcHist([src], [2], None, [256], [0,255])
cv2.imshow("src", src)
cv2.waitKey(0)
cv2.destroyAllWindows()
plt.plot(histb, color='b')
plt.plot(histg, color='g')
plt.plot(histr, color='r')
plt.show()
![[Python图像处理] 十一.灰度直方图概念及OpenCV绘制直方图 [Python图像处理] 十一.灰度直方图概念及OpenCV绘制直方图](https://cn-sec.com/wp-content/uploads/2022/05/4-1652197008.png)
四.总结
-
一.灰度直方图基本概率
-
二.绘制直方图
-
三.使用OpenCV统计绘制直方图
-
四.总结
这系列文章是当时2018年考博期间撰写的,感觉还不错。同时,回想2018年当时写这篇文章的感言,挺有意思的,每个阶段都有每个阶段的感受,并不断激励自己进步。
三尺讲台,三寸舌,
三千桃李,三杆笔。
再累再苦,站在讲台前就是最美的自己,几个月的烦恼和忧愁都已消失,真的好享受这种状态,仿佛散着光芒,终于给低年级的同学上课了越早培养编程兴趣越好,恨不能倾囊相授。即使当一辈子的教书匠,平平淡淡也喜欢,而且总感觉给学生讲课远不是课酬和职称所能比拟,这就是所谓的事业,所谓的爱好。
源代码下载地址,记得帮忙点star和关注喔!
-
https://github.com/eastmountyxz/
ImageProcessing-Python
(By:Eastmount 2022-05-10 夜于武汉 )
参考文献,在此感谢这些大佬,共勉!
-
[1] 冈萨雷斯. 数字图像处理(第3版)[M]. 电子工业出版社, 2013.
-
[2] 罗子江. Python中的图像处理[M]. 科学出版社, 2020.
-
[3] https://blog.csdn.net/Eastmount
-
[4]《计算机图形学》基础知识
-
[5] 部分内容参考网易云lilizong老师的视频
原文始发于微信公众号(娜璋AI安全之家):[Python图像处理] 十一.灰度直方图概念及OpenCV绘制直方图
- 左青龙
- 微信扫一扫
-
- 右白虎
- 微信扫一扫
-
评论