opencv python 2D直方图的示例代码


Posted in Python onJuly 20, 2018

Histograms - 3 : 2D Histograms

我们已经计算并绘制了一维直方图,因为我们只考虑一个特征,即像素的灰度强度值.但在二维直方图中,需要考虑两个特征,通常,它用于查找颜色直方图,其中两个要素是每个像素的色调和饱和度值.

OpenCV中的2D直方图

使用函数cv.calcHist(), 对于颜色直方图,我们需要将图像从BGR转换为HSV。 (请记住,对于1D直方图,我们从BGR转换为灰度)。对于2D直方图,其参数将修改如下:

  • channels = [0,1]:因为我们需要同时处理H(色调Hue)和S(饱和度Saturation).
  • bins = [180,256]:180对应H,256对应S.
  • range = [0,180,0,256]:色调值介于0到180之间,饱和度介于0到256之间.
import cv2
import numpy as np
from matplotlib import pyplot as plt

img = cv2.imread('img.jpg')

hsv = cv2.cvtColor(img,cv2.COLOR_BGR2HSV)

hist = cv2.calcHist([hsv], [0, 1], None, [180, 256], [0, 180, 0, 256])

Numpy中的2D直方图

np.histogram2d(). (注意,对于1D直方图,我们使用np.histogram()

hist, xbins, ybins = np.histogram2d(h.ravel(),s.ravel(),[180,256],[[0,180],[0,256]])

第一个参数是H平面,第二个是S平面,第三个是每个bins的数量,第四个是它们的范围

绘制2D直方图

方法 - 1:使用cv.imshow()

我们得到的结果是一个大小为180x256的二维数组. 因此我们可以像使用cv.imshow()函数一样正常显示它们. 它将是一个灰度图像,它不会告诉你什么颜色,除非你知道不同颜色的色调.

方法-2:使用Matplotlib

我们可以使用matplotlib.pyplot.imshow()函数绘制具有不同颜色图的2D直方图. 它让我们更好地了解不同的像素密度, 但是,除非你知道不同颜色的色调值,否则这也不会让我们知道第一眼看到的是什么颜色. 它简单而且更好.
代码:

import cv2
import numpy as np
from matplotlib import pyplot as plt

img = cv2.imread('img6.png')

hsv = cv2.cvtColor(img,cv2.COLOR_BGR2HSV)

hist = cv2.calcHist([hsv], [0,1], None, [180,256], [0,180,0,256])

plt.imshow(hist, interpolation='nearest')
plt.show()

opencv python 2D直方图的示例代码

opencv python 2D直方图的示例代码

在直方图中,你可以看到H=100和S=200附近的一些高值,它对应于天空的蓝色.同样,在H=25和S=100附近也可以看到另一个峰值,它对应着宫殿的黄色.

方法-3:OpenCV样本风格

在Opencv-Python2样本中有一个用于颜色直方图的示例代码(samples/python/color_histogram.py).如果您运行代码,您可以看到直方图显示相应的颜色,或者简单地输出一个颜色编码的直方图.它的结果非常好(尽管您需要添加一些额外的行).
在这段代码中,作者在HSV中创建了一个彩色地图,然后将其转换为BGR,生成的直方图图像与此颜色图相乘,他还使用一些预处理步骤来移除小的孤立像素,从而形成一个良好的直方图.

opencv python 2D直方图的示例代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中shape计算矩阵的方法示例
Apr 21 Python
Python3读取Excel数据存入MySQL的方法
May 04 Python
Python操作MySQL数据库的方法
Jun 20 Python
Python返回数组/List长度的实例
Jun 23 Python
利用pandas进行大文件计数处理的方法
Jul 25 Python
Django Python 获取请求头信息Content-Range的方法
Aug 06 Python
python线程中的同步问题及解决方法
Aug 29 Python
python使用opencv在Windows下调用摄像头实现解析
Nov 26 Python
python GUI库图形界面开发之PyQt5下拉列表框控件QComboBox详细使用方法与实例
Feb 27 Python
python GUI库图形界面开发之PyQt5单选按钮控件QRadioButton详细使用方法与实例
Feb 28 Python
通过实例简单了解Python sys.argv[]使用方法
Aug 04 Python
教你如何使用Python实现二叉树结构及三种遍历
Jun 18 Python
Linux下python制作名片示例
Jul 20 #Python
Python爬虫的两套解析方法和四种爬虫实现过程
Jul 20 #Python
使用python脚本实现查询火车票工具
Jul 19 #Python
Python 判断文件或目录是否存在的实例代码
Jul 19 #Python
Flask框架Jinjia模板常用语法总结
Jul 19 #Python
python一行sql太长折成多行并且有多个参数的方法
Jul 19 #Python
python代码过长的换行方法
Jul 19 #Python
You might like
计算一段日期内的周末天数的php代码(星期六,星期日总和)
2009/11/12 PHP
PHP IN_ARRAY 函数使用注意事项
2010/07/24 PHP
通过curl模拟post和get方式提交的表单类
2014/04/23 PHP
PHP登录环节防止sql注入的方法浅析
2014/06/30 PHP
WordPress中用于获取搜索表单的PHP函数使用解析
2016/01/05 PHP
PHP常用操作类之通信数据封装类的实现
2017/07/16 PHP
flash调用js中的方法,让js传递变量给flash的办法及思路
2013/08/07 Javascript
JavaScript中的操作符==与===介绍
2014/12/31 Javascript
javascript中的Base64、UTF8编码与解码详解
2015/03/18 Javascript
JavaScript 模块化编程(笔记)
2015/04/08 Javascript
简单介绍JavaScript中字符串创建的基本方法
2015/07/07 Javascript
原生js与jQuery实现简单的tab切换特效对比
2015/07/30 Javascript
使用jquery获取url以及jquery获取url参数的实现方法
2016/05/25 Javascript
简单实现jQuery级联菜单
2017/01/09 Javascript
AngularJS的脏检查深入分析
2017/04/22 Javascript
jQuery Masonry瀑布流布局神器使用详解
2017/05/25 jQuery
详解node nvm进行node多版本管理
2017/10/21 Javascript
原生JS无缝滑动轮播图
2019/10/22 Javascript
JS原型和原型链原理与用法实例详解
2020/02/05 Javascript
Vue如何使用混合Mixins和插件开发详解
2020/02/05 Javascript
微信小程序纯文本实现@功能
2020/04/08 Javascript
微信小程序实现自定义底部导航
2020/11/18 Javascript
[02:36]DOTA2英雄基础教程 斯拉克
2013/11/29 DOTA
[06:24]DOTA2亚洲邀请赛小组赛第三日 TOP10精彩集锦
2015/02/01 DOTA
python生成二维码的实例详解
2017/10/29 Python
详解Python开发中如何使用Hook技巧
2017/11/01 Python
python实现的自动发送消息功能详解
2019/08/15 Python
Python 3 使用Pillow生成漂亮的分形树图片
2019/12/24 Python
编译 pycaffe时报错:fatal error: numpy/arrayobject.h没有那个文件或目录
2020/11/29 Python
伦敦著名的运动鞋综合商店:Footpatrol
2019/03/25 全球购物
公司委托书格式范本
2014/09/16 职场文书
开展批评与自我批评心得体会
2014/10/17 职场文书
工作表扬信
2015/01/17 职场文书
向女朋友道歉的话
2015/01/20 职场文书
团代会闭幕词
2015/01/28 职场文书
退休欢送会致辞
2015/07/31 职场文书