python绘制灰度图片直方图-opencv+python 统计及绘制直方图
灰度直方图概括了图像的灰度级信息,简单的来说就是每个灰度级图像中的像素个数以及占有率,创建直方图无外乎两个步骤,统计直方图数据,再用绘图库绘制直方图。
统计直方图数据
首先要稍微理解一些与函数相关的术语,方便理解其在python3库中的应用和处理
BINS: 在上面的直方图当中,如果像素值是0到255,则需要256个值来显示直 方图。但是,如果不需要知道每个像素值的像素数目,只想知道两个像素值之间的像素点数目怎么办?例如,想知道像素值在0到15之间的像素点数目,然后是16到31。。。240到255。可以将256个值分成16份,每份计算综合。每个分成的小组就是一个BIN(箱)。在opencv中使用histSize表示BINS。
DIMS: 数据的参数数目。当前例子当中,对收集到的数据只考虑灰度值,所以该值为1。
RANGE: 灰度值范围,通常是[0,256],也就是灰度所有的取值范围。
统计直方图同样有两种方法,使用opencv统计直方图,函数如下:
cv2.calcHist(images, channels, mask, histSize, ranges[, hist[, accumulate]])
该函数的参数在了解以上术语加上自己百度后可以简单应用
使用numpy统计函数,主要应用numpy.histogram()函数(还有np.bincount(),还未尝试,读者可以自己尝试,大抵使用方法相同)
hist,bins = np.histogram(img.ravel(),256,[0,256])
opencv处理速度优于numpy,同时对于学习opencv的同学来说,多运用cv的处理方法无疑更利于学习。
绘制直方图
绘制直方图一般使用Matplotlib绘制 ,这里要提一下matplotlib的matplotlib.pyplot.hist()函数,该函数可以直接统计绘制中方图。统计函数为calcHist() 或 np.histogram()
这是处理的样图
cat.jpg
下面是代码实现
import cv2
import numpy as np
from matplotlib import pyplot as plt
img = cv2.imread('/home/yc/Pictures/cat.jpg',0)
plt.hist(img.ravel(),256,[0,256]);
plt.show()
效果
灰度直方图
当然,在颜色图像检索之类用法时,我们需要的是BGR直方图,原理类似,统计时使用cv2.calcHist()函数
import cv2
import numpy as np
from matplotlib import pyplot as plt
img = cv2.imread('/home/yc/Pictures/cat.jpg',1)
color = ('b','g','r')
for i,col in enumerate(color):
histr = cv2.calcHist([img],[i],None,[256],[0,256])
plt.plot(histr,color = col)
plt.xlim([0,256])
plt.show()
效果如下
BGR直方图
此外,再介绍一种很原始的计算灰度直方图的方法……感觉代码注释的很完整,相信读者也可以看懂
import sys
import numpy as np
import cv2
import matplotlib.pyplot as plt
def main():
img=cv2.imread('/home/yc/Pictures/cat.jpg',0)
#得到计算灰度直方图的值
xy=xygray(img)
#画出灰度直方图
x_range=range(256)
plt.plot(x_range,xy,"r",linewidth=2,c='black')
#设置坐标轴的范围
y_maxValue=np.max(xy)
plt.axis([0,255,0,y_maxValue])
#设置坐标轴的标签
plt.xlabel('gray Level')
plt.ylabel("number of pixels")
plt.show()
def xygray(img):
#得到高和宽
rows,cols=img.shape
#存储灰度直方图
xy=np.zeros([256],np.uint64)
for r in range(rows):
for c in range(cols):
xy[img[r][c]] += 1
#返回一维ndarry
return xy
main()
效果如下
灰度直方图
第一次写文章,且当做学习笔记,各位大佬如果发现错误务必告诉我~
与一起学习opencv的同学共勉
python绘制灰度图片直方图-opencv+python 统计及绘制直方图相关推荐
- 如何在Python中获取图片分辨率?——Python实现获取图片分辨率的代码及详解。
如何在Python中获取图片分辨率?--Python实现获取图片分辨率的代码及详解. 在进行图片处理或者图片分析的时候,获取图片的分辨率信息是必不可少的.Python提供了许多库可以方便地获取图片的分 ...
- python绘制灰度图片直方图-python数字图像处理实现直方图与均衡化
在图像处理中,直方图是非常重要,也是非常有用的一个处理要素. 在skimage库中对直方图的处理,是放在exposure这个模块中. 1.计算直方图 函数:skimage.exposure.histo ...
- python绘制灰度图片直方图-python数字图像处理(9):直方图与均衡化
在图像处理中,直方图是非常重要,也是非常有用的一个处理要素. 在skimage库中对直方图的处理,是放在exposure这个模块中. 1.计算直方图 函数:skimage.exposure.histo ...
- python灰度图片格式_[Python图像处理] 十五.图像的灰度线性变换
[Python图像处理] 十五.图像的灰度线性变换 发布时间:2019-03-28 00:08, 浏览次数:619 , 标签: Python 该系列文章是讲解Python OpenCV图像处理知识,前 ...
- python pypdf2另存为图片_用Python玩转PDF的各种骚操作
文/Python数据科学 图片来源于网络 Portable Document Format(可移植文档格式),或者PDF是一种文件格式,可以用于跨操作系统的呈现和文档交换.尽管PDF最初是由Adob ...
- python 还原九宫格图片_用Python做一个好玩的朋友圈九宫格抽奖
最近在朋友圈看到个好玩的抽奖九宫格: 随便点开一个: 设计思路 以朋友圈中看到的1号图做参考,我们需要准备 300*900 的白色底图,搞笑表情图,广告语,中间一个醒目的数字编号,外加下方的嘲讽&qu ...
- ocr python opencv_如何使用(opencv/python)来实现OCR处
今天我们来介绍一下如何使用(opencv/python)来实现OCR处理银行票据.文末有代码和相关文档下载! 在第一部分中,我们将讨论两个主题: 1.首先,我们将了解MICR E-13B字体,美国,英 ...
- python显示gif图片_利用Python制作GIF图片
#Python制作GIF图片 import imageio def create_gif(image_list, gif_name, duration = 0.1): ''' :param image ...
- python 查找损坏图片_使用Python查找损坏的图像
python 查找损坏图片 赶上本系列: 第1部分:使用Python自动执行数字艺术家的重复任务 第2部分:针对数字艺术家的Python文件管理技巧 如果您正在计算机上处理图像,那么最终一定会遇到 ...
最新文章
- C++,Java,Python,Fortran到底哪个更快?
- mysql 连接查询两个条件_MySQL之多表查询一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习...
- 为啥这么多程序员大佬学习Cortex-M3
- mysqldump 使用备忘
- 3点 刚体运动 opencv_模态法动力学分析中的刚体模态
- 【蜕变之路】第15天 Eclipse常用问题 (2019年3月5日)
- Oracle中的AWR,全称为Automatic Workload Repository
- python生成个性二维码学习笔记
- 美国专家声讨物联网安全 面对攻击如纸糊
- salt-API基本验证命令
- 无线WIFI WPS认证机制破解
- 计算机没有显示光盘图标,电脑光驱图标不见了怎么办
- Android Studio历史版本
- C盘清理 / 磁盘清理
- Markdown文档书写方法(工具+示例+验证)
- 【学习周记】学习之路,任重而道远
- LSL学习笔记(3)
- JavaScript中的get和set方法讲解
- wxh play 组织结构图
- Spring JDBC 访问数据库
热门文章
- matlab的syms无法在函数中使用_EXCEL中查找匹配函数VLOOKUP使用技巧
- html5 list css,使用HTML5的classList属性操做CSS类
- (传送门)instant run原理
- Mybatis优缺点
- Cannot change version of project facet Dynamic Web Module to 3.0.
- 50岁,他希望自己还可以写代码
- 【BZOJ 3747】 3747: [POI2015]Kinoman (线段树)
- 前端面试题(html篇)
- 最短路径算法——Dijkstra and Floyd算法
- AspNetPager7.2的基本使用