您当前的位置:首页 > IT编程 > python
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

自学教程:OpenCV半小时掌握基本操作之直方图

51自学网 2021-10-30 22:14:45
  python
这篇教程OpenCV半小时掌握基本操作之直方图写得很实用,希望能帮到您。

【OpenCV】⚠️高手勿入!⚠️ 半小时学会基本操作 ⚠️ 直方图

概述

OpenCV 是一个跨平台的计算机视觉库, 支持多语言, 功能强大. 今天小白就带大家一起携手走进 OpenCV 的世界. (第 20 课)

在这里插入图片描述

直方图

原图:

在这里插入图片描述

cv2.calcHist()可以帮助我们统计像素并得到直方图.

格式:

calcHist(images, channels, mask, histSize, ranges, hist=None, accumulate=None)

参数:

  • images: 输入图像
  • channels: 颜色通道
  • mask: 掩模
  • histSize: bin 的数目, 用中括号括起来
  • ranges: 像素范围 [0, 256]

例 1 (灰度图统计直方图):

import cv2from matplotlib import pyplot as pltplt.style.use("fivethirtyeight")# 读取图片, 并转换成灰度图img = cv2.imread("girl.jpg", 0)# 获取直方图hist = cv2.calcHist([img], [0], None, [256], [0, 256])print(hist)# 直方图展示plt.figure(figsize=(12, 6))plt.plot(hist)plt.title("hist of image")plt.show()

输出结果:

在这里插入图片描述

例 2 (RGB 三通道直方图):

import cv2from matplotlib import pyplot as pltplt.style.use("fivethirtyeight")plt.figure(figsize=(12, 6))# 读取图片img = cv2.imread("girl.jpg")# 颜色通道color = ["b", "g", "r"]# 获取直方图for i, c in enumerate(color):    hist = cv2.calcHist([img], [i], None, [256], [0, 256])    plt.plot(hist, color=c)# 直方图展示plt.legend(["B Channel", "G Channel", "R Channel"])plt.title("RGB hist of image")plt.show()

输出结果:

在这里插入图片描述

直方图 + mask

例子:

import numpy as npimport cv2from matplotlib import pyplot as pltplt.style.use("fivethirtyeight")# 读取图片, 并转换成灰度图img = cv2.imread("girl.jpg", 0)# 创建maskmask = np.zeros(img.shape, np.uint8)mask[280:1000, 420:1500] = 255# 获取mask后的图像masked_img = cv2.bitwise_and(img, img, mask=mask)# 直方图hist_full = cv2.calcHist([img], [0], None, [256], [0, 256])hist_mask = cv2.calcHist([img], [0], mask, [256], [0, 256])# 图片展示f, ax = plt.subplots(2, 2, figsize=(12, 9))ax[0, 0].imshow(img, 'gray')ax[0, 0].set_title("original image")ax[0, 1].imshow(mask, 'gray')ax[0, 1].set_title("mask")ax[1, 0].imshow(masked_img, 'gray')ax[1, 0].set_title("masked image")ax[1, 1].plot(hist_full)ax[1, 1].plot(hist_mask)ax[1, 1].set_title("original vs masked hist")plt.show()

输出结果:

在这里插入图片描述

直方图均衡化

直方图均衡化 (Histogram Equalization) 是一种增强图片对比度的方法. 将一副图像的直方图分布变成近似均匀分布.

格式:

cv2.equalizeHist(src, dst=None)

例子:

import cv2from matplotlib import pyplot as pltplt.style.use("fivethirtyeight")# 读取图片, 并转换成灰度图img = cv2.imread("girl.jpg", 0)# 均衡化img_equ = cv2.equalizeHist(img)# 直方图f, ax = plt.subplots(2, 2, figsize=(16, 16))ax[0, 0].imshow(img, "gray")ax[0, 0].set_title("before")ax[0, 1].imshow(img_equ, "gray")ax[0, 1].set_title("after")ax[1, 0].hist(img.ravel(), 256)ax[1, 1].hist(img_equ.ravel(), 256)plt.show()

输出结果:

在这里插入图片描述

到此这篇关于OpenCV半小时掌握基本操作之直方图的文章就介绍到这了,更多相关OpenCV直方图内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net!


使用OpenCV为图像加水印的教程
Python调用两个机器人聊天的实战
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。