最大熵阈值python_【6】python-opencv3教程:阈值分割(全阈值分割,局部阈值分割,直方图技术法,熵算法,自适应算法,Otsu算法)...

第六节:阈值分割

一: 全阈值分割

实例代码:

image = cv2.imread('img.jpg', cv2.IMREAD_GRAYSCALE)

the = 100 # 设置阈值为100

maxval = 255

dst, img = cv2.threshold(image, the, maxval, cv2.THRESH_BINARY)

cv2.imshow('hand_thresh', img)

cv2.waitKey(0)

cv2.destroyAllWindows()

给出你的阈值 ,然后告诉你的最大阈值是多少 。。。也就是你二值图中一个阈值为0,另外一个阈值可以指定为多少。。这里指定为255

看一下输出结果。。

二:局部阈值分割

局部阈值分割的核心是计算阈值矩阵。。比较常用的是后面提到的自适应阈值算法。。我们等会后面讲实现。。

三:直方图技术法

代码实现:

import numpy as np

import cv2

def calcGrayHist(image):

'''

统计像素值

:param image:

:return:

'''

# 灰度图像的高,宽

rows, cols = image.shape

# 存储灰度直方图

grayHist = np.zeros([256], np.uint64)

for r in range(rows):

for c in range(cols):

grayHist[image[r][c]] += 1

return grayHist

def threshTwoPeaks(image):

# 计算灰度直方图

histogram = calcGrayHist(image)

# 找到灰度直方图的最大峰值对应的灰度值

maxLoc = np.where(histogram == np.max(histogram))

firstPeak =

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值