OpenCV-Python之图像直方图的反向投影

这个技术常常用来跟踪目标,且需要转换在HSV色彩空间

1.建立2D直方图

import cv2 as cv
import matplotlib.pyplot as plt
import numpy as np

def hist2D_demo(image):
    hsv = cv.cvtColor(image, cv.COLOR_BGR2HSV)
    hist = cv.calcHist([hsv],[0, 1], None, [180, 256], [0, 180, 0, 255])
    plt.imshow(hist, interpolation='nearest')
    plt.title('Histogram 2D image')
    plt.show()

src = cv.imread('./data/lena.jpg', 1)
cv.imshow('souce', src)
hist2D_demo(src)
cv.waitKey(0)
cv.destroyAllWindows()

calcHist说明

  • 其中第一个参数必须用方括号括起来。
  • 第二个参数是用于计算直方图的通道;
  • 第三个参数是Mask,这里没有使用,所以用None。
  • 第四个参数是histSize,表示这个直方图分成多少份(即多少个直方柱)
  • 第五个参数是表示直方图中各个像素的值,[0.0, 256.0]表示直方图能表示像素值从0.0到256的像素。
  • 最后是两个可选参数,由于直方图作为函数结果返回了,所以第六个hist就没有意义了(待确定)
  • 最后一个accumulate是一个布尔值,用来表示直方图是否叠加。



若更改

 hist = cv.calcHist([hsv],[0, 1], None, [32, 32], [0, 180, 0, 255])


2.建立直方图反向投影

import cv2 as cv
import matplotlib.pyplot as plt
import numpy as np

def hist_projection_demo():
    target = cv.imread('./data/real-madrid-vs-juventus.png',1)
    sample = cv.imread('./data/violet.png',1)

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

    cv.imshow('simple image', sample)
    cv.imshow('target image', target)

    sampleHist = cv.calcHist([sample_hsv], [0, 1], None ,[32, 48], [0, 180, 0, 256])
    cv.normalize(sampleHist,sampleHist,0, 255, cv.NORM_MINMAX)
    dst = cv.calcBackProject([target_hsv], [0,1], sampleHist, [0,180,0,256],1)
    cv.imshow('projectionHistogram image', dst)


def hist2D_demo(image):
    hsv = cv.cvtColor(image, cv.COLOR_BGR2HSV)
    hist = cv.calcHist([hsv],[0, 1], None, [180, 256], [0, 180, 0, 255])
    plt.imshow(hist, interpolation='nearest')
    plt.title('Histogram 2D image')
    plt.show()


hist_projection_demo()
cv.waitKey(0)
cv.destroyAllWindows()



全部评论

相关推荐

程序员花海:实习和校招简历正确格式应该是教育背景+实习+项目经历+个人评价 其中项目经历注意要体现业务 实习经历里面的业务更是要自圆其说 简历模板尽可能保持干净整洁 不要太花哨的
点赞 评论 收藏
分享
2025-12-12 19:01
南京航空航天大学 C++
秋招没咋投,准备 wxg 转正之后摆烂了。结果不堪字节 HR 的骚扰还是面了一下字节。之前想去字节的时候怎么面都挂。现在想着随便面一下结果三面技术面都意外顺利还有加面。十月中旬字节发了意向,wxg 转正结果无响应。十月底字节拉了保温群,wxg 口头通过,系统显示考核中。十一月初和字节 ld 交流之后得知 base 居然能选海外,甚至能小 wlb 一下,wxg 无响应无人联系。十一月中旬把字节 base 转到了海外,wxg 流程灰了,一问超时忘处理了,过两天又变考核中了。十一月下旬字节换了海外 HR 对接,问了期望薪资,wxg 考核终于显示通过,无 HR 保温,无其他保温。十一月底给字节报了个天价,想吓吓他们,同时告诉微信字节要开了,微信无响应。同样十一月底字节 HR 告诉我确实给不到那么高,但是能拿期权补上,问能不能接受。微信无响应。同样十一月底字节 HR 告知了具体方案,符合预期。 微信无响应。十二月上旬催 wxg 不开我就盲拒了,wxg HR 火急火燎的打电话问情况,问期望。我给了一个不算夸张的总包数字,因为今年市场在涨,过了三天还不联系我,我再催,约时间下午打电话,非得在我给出的数字上压下去几万,微信又不差这点,为什么不能满足我,让我没有拒绝的理由呢?一番纠结抗争,求稳还是追求挑战,最终选择接受迎接新的挑战,因为堂吉诃德永远不会停下脚步!回想起来,在 wxg 谈薪的阶段,我认为并没有给予我一定的重视,即使 HR 表示我在实习期间的表现和之前的面评都很靠前。也没有感觉到想要争取我,虽然我表示拒了 offer 之后要给我加面委定 t6 再涨,但我三个月没面试让我面面委那就是白给,还是算了。有缘再见了我亲爱的 wxg,再见了曾经的梦中情厂,再见亲爱的 mt,再见亲爱的朋友们。也再见,北京的一切。我想润了。秋招结束,卸载牛客,下一个三年,下一个五年,下一个十年后再来看看。
面试中的大熊猫爱吃薯...:我嫉妒得狗眼通红
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务