OpenCV灰度图像直方图算法实现
2019-05-13 00:00
627 查看
手动实现一个灰度直方图算法,过程很简单,主要有以下几步:
1. 统计每一个像素灰度值
2. 计算每个灰度值出现的概率
3. 横坐标 0-255
4. 纵坐标为概率P
直方图效果如下:
# 本质: 统计每一个像素灰度 出现的概率 横坐标 0-255 纵坐标 概率P
import cv2
import numpy as np
import matplotlib.pyplot as plt
img = cv2.imread('wwww.linuxidc.com.jpg', 1)
imgInfo = img.shape
height = imgInfo[0]
width = imgInfo[1]
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
count = np.zeros(256, np.float) # 因为是概率, 有可能是浮点数
# 统计像素个数并计算概率
for i in range(height):
for j in range(width):
pixel = gray[i, j]
index = int(pixel)
count[index] = count[index] + 1
total = height * width # 总像素个数
count = count / total # 计算概率
# 画图
x = np.linspace(0, 255, 256)
y = count
plt.bar(x, y, 0.9, alpha = 1, color = "b")
plt.show()
效果如下:
更多Python相关信息见Python 专题页面 https://www.linuxidc.com/topicnews.aspx?tid=17
相关文章推荐
- 利用OpenCV的threshold函数实现双阈值法二值化操作的源码!
- 学习OpenCV(三)用filter2D实现矩阵掩码操作
- OpenCV常见算法实现(一)- 椒盐噪声
- 在OpenCV中图像边界扩展 copyMakeBorder 的实现
- 双目测距与三维重建的OpenCV实现问题集锦(二)双目定标与双目校正
- opencv 实现对摄像头输入图像中文件及证件等的实时跟踪,四边形检测及提取
- Opencv之分水岭原理和实现
- 贪吃蛇小游戏—C++、Opencv编写实现
- OpenCV中图像旋转(warpAffine)算法的实现过程
- VS2010实现opencv基于DCT的图像压缩
- OpenCV实现SVM分类器
- opencv实现图像旋转
- 使用OpenCv+ENet实现语义分割
- opencv的sobel算子(自己实现与官方比较)
- 利用python opencv实现图像自适应二值化
- Python基于opencv实现的简单画板功能示例
- opencv实现拉普拉斯锐化的总结
- 【openCV】matlab中bwareaopen和bwmorph(src, 'thin', Inf)opencv下的实现
- opencv 矩阵与一个常数相乘的 两种实现方法
- 利用OpenCV 2.2 的Python接口实现Ostu(大津法)获取阈值