python opencv 直方图均衡_opencv python:图像直方图 histogram

直接用matplotlib画出直方图

def plot_demo(image):

plt.hist(image.ravel(), 256, [0, 256]) # image.ravel()将图像展开,256为bins数量,[0, 256]为范围

plt.show()

图像直方图

def image_hist(image):

color = ('blue', 'green', 'red')

for i, color in enumerate(color):

# 计算出直方图,calcHist(images, channels, mask, histSize(有多少个bin), ranges[, hist[, accumulate]]) -> hist

# hist 是一个 256x1 的数组,每一个值代表了与该灰度值对应的像素点数目。

hist = cv.calcHist(image, [i], None, [256], [0, 256])

print(hist.shape)

plt.plot(hist, color=color)

plt.xlim([0, 256])

plt.show()

直方图均值化

是图像增强的一个手段

def equalHist_demo(image):

gray = cv.cvtColor(image,cv.COLOR_BGR2GRAY)

# 全局直方图均衡化,用于增强图像对比度,即黑的更黑,白的更白

dst = cv.equalizeHist(gray)

cv.imshow("equalHist_demo", dst)

# 局部直方图均衡化

clahe = cv.createCLAHE(clipLimit=2.0, tileGridSize=(8, 8))

clahe_dst = clahe.apply(gray)

cv.imshow("clahe", clahe_dst)

直方图比较

20200129234703252341.png

# 创建直方图

def create_rgb_demo(image):

h, w, c = image.shape

rgbHist = np.zeros([16*16*16, 1], np.float32)

bsize = 256 / 16

for row in range(h):

for col in range(w):

b = image[row, col, 0]

g = image[row, col, 1]

r = image[row, col, 2]

index = np.int(b/bsize)*16*16 + np.int(g/bsize)*16 + np.int(r/bsize)

rgbHist[np.int(index), 0] = rgbHist[np.int(index), 0] + 1

return rgbHist

# 利用直方图比较相似性,用巴氏和相关性比较好

def hist_compare(image1, image2):

hist1 = create_rgb_demo(image1)

hist2 = create_rgb_demo(image2)

match1 = cv.compareHist(hist1, hist2, method=cv.HISTCMP_BHATTACHARYYA)

match2 = cv.compareHist(hist1, hist2, method=cv.HISTCMP_CORREL)

match3 = cv.compareHist(hist1, hist2, method=cv.HISTCMP_CHISQR)

print("巴式距离:%s, 相关性:%s, 卡方:%s"%(match1, match2, match3))

直方图反向投影

import cv2 as cv

import numpy as np

import matplotlib.pyplot as plt

def hist2d_demo(image):

hsv = cv.cvtColor(image, cv.COLOR_BGR2HSV)

hist = cv.calcHist([image], [0, 1], None, [180, 360], [0, 180, 0, 256]) # 计算直方图

print(hist.shape)

# cv.imshow("hist2d_demo", hist)

plt.imshow(hist, interpolation="nearest") # 直方图显示

plt.title("2D Histogram")

plt.show()

# OpenCV 提供的函数 cv2.calcBackProject() 可以用来做直方图反向 投影。

# 它的参数与函数 cv2.calcHist 的参数基本相同。其中的一个参数是我 们要查找目标的直方图。

# 同样再使用目标的直方图做反向投影之前我们应该先对其做归一化处理。

# 返回的结果是一个概率图像

def back_projection_demo():

"""

反向投影可以用来做图像分割,或者在图像中找寻我们感兴趣的部分。

它会输出与输入图像(待搜索)同样大小的图像,其中的每一个像素值代表了输入图像上对应点属于目标对象的概率。

输出图像中像素值越高(越白)的点就越可能代表我们要搜索的目标 (在输入图像所在的位置)。

直方图投影经常与camshift 算法等一起使用。

步骤:

1. 为一张包含我们要查找目标的图像创建直方图,我们要查找的对象要尽量占满这张图像。

最好使用颜色直方图,因为一个物体的颜色要比它的灰 度能更好的被用来进行图像分割与对象识别。

2. 们再把这个颜色直方图投 影到输入图像中寻找我们的目标,

也就是找到输入图像中的每一个像素点的像素值在直方图中对应的概率,这样我们就得到一个概率图像。

3. 设置适当的阈值对概率图像进行二值化

"""

sample = cv.imread("../images/roi.png")

target = cv.imread("../images/CrystalLiu3.jpg")

roi_hsv = cv.cvtColor(sample, cv.COLOR_BGR2HSV)

target_hsv = cv.cvtColor(target, cv.COLOR_BGR2HSV)

cv.imshow("sample", sample)

cv.imshow("target", target)

roiHist = cv.calcHist([roi_hsv], [0, 1], None, [180, 256], [0, 180, 0, 256])

# 归一化:原始图像,结果图像,映射到结果图像中的最小值,最大值,归一化类型

# cv.NORM_MINMAX对数组的所有值进行转化,使它们线性映射到最小值和最大值之间

# 归一化后的图像便于显示,归一化后到0,255之间了

cv.normalize(roiHist, roiHist, 0, 255, cv.NORM_MINMAX)

dst = cv.calcBackProject([target_hsv], [0, 1], roiHist, [0, 180, 0, 256], 1)

cv.imshow("backProjectionDemo", dst)

if __name__ == '__main__':

src = cv.imread("../images/CrystalLiu1.jpg") # 读入图片放进src中

cv.namedWindow("Crystal Liu") # 创建窗口

cv.imshow("Crystal Liu", src) # 将src图片放入该创建的窗口中

hist2d_demo(src)

# back_projection_demo()

cv.waitKey(0) # 等有键输入或者1000ms后自动将窗口消除,0表示只用键输入结束窗口

cv.destroyAllWindows() # 关闭所有窗口

原文地址:https://www.cnblogs.com/wbyixx/p/12241569.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值