像素直方图的双峰位置查找

若一张图像的像素直方图中存在较为明显的双峰,则找到双峰对应的位置可以再直方图阈值分割中起到重要的作用,像素直方图统计可以用hist=cv2.calcHist(img)实现,最大峰值可以用np.where(hist==hist.max())实现,则第二峰值可以用以下算式计算:

其中k表示像素灰度值(以0-255为例),firstpeak为像素数最多的那个像素值,即第一峰值,histogram(k)表示随着像素值k的变化,图像上k像素值对应的像素个数。该部分代码如下:

 

#像素直方图双峰值 

    histogram = cv.calcHist(gray)
    #寻找灰度直方图的最大峰值对应的灰度值
    maxLoc = np.where(histogram==np.max(histogram))
    firstPeak = maxLoc[0][0]
    #寻找灰度直方图的第二个峰值对应的灰度值
    measureDists = np.zeros([256],np.float32)
    for k in range(256):
        measureDists[k] = pow(k-firstPeak,2)*histogram[k]
    maxLoc2 = np.where(measureDists==np.max(measureDists))
    secondPeak = maxLoc2[0][0]

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值