当前位置: 首页 > news >正文

OpenCV-Python(22):2D直方图

目标

  • 了解图像的2D直方图
  • 绘制2D直方图

介绍 

        在前面的部分我们介绍了如何绘制一维直方图,之所以称为一维,是因为我们只考虑了图像的一个特征:灰度值。但是在2D 直方图中我们就需要考虑两个图像特征。对于彩色图像的直方图通常情况下我们需要考虑每个的颜色(Hue)和饱和度(Saturation)根据这两个特征绘制2D 直方图。

        2D直方图是一种用于描述二维图像的统计工具,它可以用来表示图像中不同像素值的分布情况。与一维直方图类似,2D直方图将图像中每个像素的坐标映射到一个二维直方图中的一个bin中,从而得到一个二维数组。在2D直方图中,x轴和y轴分别表示图像中的两个像素值的范围,而每个bin的高度表示在该像素值范围内的像素的数量。因此,通过分析2D直方图,我们可以了解不同像素值之间的关系,以及它们在图像中的分布情况。

        2D直方图常用于图像分割、目标检测和图像匹配等应用中。通过计算两幅图像的2D直方图,并比较它们的相似性,可以进行图像匹配和目标检测。此外,通过对2D直方图进行阈值化或二值化处理,可以实现图像分割,将图像中的前景和背景分离开来。

OpenCV 中的2D 直方图

cv2.calcHist()函数是OpenCV中用于计算直方图的函数之一,它可以计算一维或多维的直方图。在计算二维直方图时,需要指定两幅图像的通道和bin的数量。

函数的语法如下:

hist = cv2.calcHist(images, channels, mask, histSize, ranges[, hist[, accumulate]])

参数说明:

  • images: 输入图像,可以是单通道或多通道图像。如果是多通道图像,则需要指定通道。
  • channels: 需要计算直方图的通道,如果是多通道图像,则需要指定通道索引。对于灰度图像,通道索引为[0],对于彩色图像,通道索引为[0, 1, 2]分别表示蓝色、绿色和红色通道。
  • mask: 掩码图像,用于指定计算直方图的区域。如果不需要指定区域,则可以传入None。
  • histSize: bin的数量,用于指定直方图的分辨率。例如,[256]表示每个通道有256个bin。
  • ranges: bin的范围,用于指定像素值的范围。例如,对于灰度图像,范围为[0, 256]表示像素值的范围为0到255。

返回值:

  • hist: 计算得到的直方图。是一个二维数组,每个bin的高度表示在该像素值范围内的像素的数量。

示例代码:

import cv2
import numpy as npimg = cv2.imread('image.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)hist = cv2.calcHist([gray], [0], None, [256], [0, 256])cv2.imshow('Image', img)
cv2.imshow('Histogram', hist)
cv2.waitKey(0)
cv2.destroyAllWindows()

上述代码中,首先读取一幅图像并将其转换为灰度图像。然后使用cv2.calcHist()函数计算灰度图像的直方图,bin的数量为256,像素值范围为[0, 256]。最后使用cv2.imshow()函数显示图像和直方图。

注意:直方图是一种统计工具,它不仅可以用于灰度图像,还可以用于彩色图像和多通道图像。对于彩色图像,需要分别计算每个通道的直方图,并将它们合并在一起。

Numpy中2D直方图

        在NumPy中,可以使用np.histogram2d()函数计算二维直方图。该函数可以计算两个二维数组的直方图,其中第一个数组表示x轴的值,第二个数组表示y轴的值。

函数的语法如下:

hist, x_edges, y_edges = np.histogram2d(x, y, bins)

参数说明:

  • x: 一个一维数组,表示x轴的值。
  • y: 一个一维数组,表示y轴的值。
  • bins: 一个整数或表示bin的序列。如果是整数,则表示x和y轴上的bin的数量。如果是序列,则表示每个轴上的bin的边界值。

返回值:

  • hist: 计算得到的二维直方图。是一个二维数组,每个元素表示在对应区域内的样本数量。
  • x_edges: x轴上的bin边界值。
  • y_edges: y轴上的bin边界值。

示例代码:

import numpy as np
import matplotlib.pyplot as plt# 生成随机数据
np.random.seed(0)
x = np.random.randn(1000)
y = np.random.randn(1000)# 计算二维直方图
hist, x_edges, y_edges = np.histogram2d(x, y, bins=10)# 绘制二维直方图
plt.imshow(hist, interpolation='nearest', origin='low', extent=[x_edges[0], x_edges[-1], y_edges[0], y_edges[-1]])
plt.colorbar()
plt.xlabel('x')
plt.ylabel('y')
plt.title('2D Histogram')
plt.show()

上述代码中,首先使用NumPy的np.random.randn()函数生成1000个随机数作为x和y轴的值。然后使用np.histogram2d()函数计算二维直方图,bin的数量为10。最后使用Matplotlib的plt.imshow()函数绘制二维直方图,并使用plt.colorbar()函数添加颜色条。

绘制2D直方图 

在Python中,除了使用NumPy和Matplotlib库之外,还可以使用其他库来绘制2D直方图,例如Seaborn和Plotly。

1.使用Seaborn库绘制2D直方图:
Seaborn是一个基于Matplotlib的统计数据可视化库,可以使绘图更加美观和简单。Seaborn库提供了jointplot()函数来绘制二维直方图。

示例代码:

import seaborn as sns# 生成随机数据
np.random.seed(0)
x = np.random.randn(1000)
y = np.random.randn(1000)# 绘制二维直方图
sns.jointplot(x=x, y=y, kind='hist')
plt.show()

上述代码中,首先使用NumPy的np.random.randn()函数生成1000个随机数作为x和y轴的值。然后使用Seaborn的jointplot()函数绘制二维直方图,并指定kind='hist'参数表示绘制直方图。最后使用Matplotlib的plt.show()函数显示图像。

2.使用Plotly库绘制2D直方图:
Plotly是一个交互式可视化库,支持绘制各种类型的图表。Plotly库提供了histogram2d()函数来绘制二维直方图。

示例代码:

import plotly.express as px# 生成随机数据
np.random.seed(0)
x = np.random.randn(1000)
y = np.random.randn(1000)# 绘制二维直方图
fig = px.histogram(x=x, y=y, nbinsx=10, nbinsy=10)
fig.show()

上述代码中,首先使用NumPy的np.random.randn()函数生成1000个随机数作为x和y轴的值。然后使用Plotly的histogram()函数绘制二维直方图,并指定nbinsxnbinsy参数表示x和y轴上的bin的数量。最后使用fig.show()函数显示图像。

 

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • TensorFlow Hub模型
  • 拓展操作(三) jenkins迁移到另一个机器
  • 关键字:try-catch关键字
  • Ubuntu安装WordPress并使用Nginx作为Web服务器
  • Openwrt修改Dropbear ssh root密码
  • 数据流的中位数
  • 非常好用的ocr图片文字识别技术,识别图片中的文字
  • 【教学类-43-03】20231229 N宫格数独3.0(n=1、2、3、4、6、8、9) (ChatGPT AI对话大师生成 回溯算法)
  • 前端文件在虚拟机,后端在本机,两个如何通信
  • 2022年12月10日-2023年12月28日
  • Maven的使用和配置
  • 【java爬虫】使用element-plus进行个股详细数据分页展示
  • 记录:开始学习网络安全
  • 玩转贝启科技BQ3588C开源鸿蒙系统开发板 —— 代码下载(3)
  • 从仿写持久层框架到MyBatis核心源码阅读
  • 【知识碎片】第三方登录弹窗效果
  • 0基础学习移动端适配
  • Android开发 - 掌握ConstraintLayout(四)创建基本约束
  • Javascripit类型转换比较那点事儿,双等号(==)
  • java中具有继承关系的类及其对象初始化顺序
  • JSONP原理
  • oschina
  • PhantomJS 安装
  • Spring Cloud(3) - 服务治理: Spring Cloud Eureka
  • 大整数乘法-表格法
  • 简单实现一个textarea自适应高度
  • 前端代码风格自动化系列(二)之Commitlint
  • 如何用vue打造一个移动端音乐播放器
  • 算法-插入排序
  • 通过几道题目学习二叉搜索树
  • 我感觉这是史上最牛的防sql注入方法类
  • 一起参Ember.js讨论、问答社区。
  • Android开发者必备:推荐一款助力开发的开源APP
  • ​LeetCode解法汇总2670. 找出不同元素数目差数组
  • ​字​节​一​面​
  • #进阶:轻量级ORM框架Dapper的使用教程与原理详解
  • #我与Java虚拟机的故事#连载09:面试大厂逃不过的JVM
  • (1)(1.13) SiK无线电高级配置(六)
  • (1)(1.13) SiK无线电高级配置(五)
  • (1)常见O(n^2)排序算法解析
  • (2)(2.4) TerraRanger Tower/Tower EVO(360度)
  • (2024,RWKV-5/6,RNN,矩阵值注意力状态,数据依赖线性插值,LoRA,多语言分词器)Eagle 和 Finch
  • (Pytorch框架)神经网络输出维度调试,做出我们自己的网络来!!(详细教程~)
  • (vue)el-cascader级联选择器按勾选的顺序传值,摆脱层级约束
  • (笔记)Kotlin——Android封装ViewBinding之二 优化
  • (附源码)ssm高校升本考试管理系统 毕业设计 201631
  • (附源码)ssm高校志愿者服务系统 毕业设计 011648
  • (六)软件测试分工
  • (四)JPA - JQPL 实现增删改查
  • (转载)(官方)UE4--图像编程----着色器开发
  • **PHP分步表单提交思路(分页表单提交)
  • ./indexer: error while loading shared libraries: libmysqlclient.so.18: cannot open shared object fil
  • .Net 8.0 新的变化
  • .NET Core引入性能分析引导优化
  • .NET6使用MiniExcel根据数据源横向导出头部标题及数据