OpenCV:固定阈值分割、自动阈值分割

OpenCV:固定阈值分割、自动阈值分割

固定阈值分割

import cv2
from matplotlib import pyplot as plt

img = cv2.imread('影子.jpg', 0)       #0表示读取为灰度图

# img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)     #灰度图

'''
对像素数量进行统计
1:输入图像.2。待计算的通道;3.Mask,没使用,用None;4.横坐标份数;5.要统计的像素范围
'''
hist = cv2.calcHist([img], [0], None, [256], [0, 300])
plt.plot(hist)
plt.show()


'''固定阈值分割'''

r1, img1 = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY)      #大于阈值变为255,小于阈值变为0
r2, img2 = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY_INV)      #大于阈值变为0,小于阈值变为255
r3, img3 = cv2.threshold(img, 127, 255, cv2.THRESH_TRUNC)       #大于阈值变为阈值,小于阈值保持不变
r4, img4 = cv2.threshold(img, 127, 255, cv2.THRESH_TOZERO)       #大于阈值保持不变,小于阈值变为0
r5, img5 = cv2.threshold(img, 127, 255, cv2.THRESH_TOZERO_INV)       #大于阈值变为0,小于阈值保持不变

cv2.imshow('原图', img)
cv2.imshow('大于阈值变为255', img1)
cv2.imshow('大于阈值变为0', img2)
cv2.imshow('大于阈值变为阈值', img3)
cv2.imshow('大于阈值保持不变', img4)
cv2.imshow('小于阈值保持不变', img5)



cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述
自动阈值分割

import cv2
from matplotlib import pyplot as plt

img = cv2.imread('影子.jpg', 0)       #0表示读取为灰度图

# img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)     #灰度图

'''自动阈值分割 :自适应阈值法、Otsu大津法'''

img_Z_M = cv2.adaptiveThreshold(img, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 9, 4)
img_Z_G = cv2.adaptiveThreshold(img, 255, cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY, 9, 4)
'''cv2.adaptiveThreshold(src, maxValue, adaptiveMethod, thresholdType, blockSize, C)
src:输入图像
maxValue:最大阈值,一般为255
adaptiveMethod:小区域阈值计算方法
cv2.ADAPTIVE_THRESH_MEAN_C:小区域平均值
cv2.ADAPTIVE_THRESH_GAUSSIAN_C:小区域通过高斯核加权求和
thresholdType:方式,同上5种
blockSize:小区域面积,奇数。例:5代表5*5
C:小区域阈值计算值减去此值为最终阈值结果
'''

'''cv2.THRESH_OTSU;大津法'''
r_D, img_D = cv2.threshold(img, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)
img_G = cv2.GaussianBlur(img, (3, 3), 0)
r_G_D, img_G_D = cv2.threshold(img_G, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)		#0为初始阈值,从0开始计算


cv2.imshow('原图', img)
cv2.imshow('自适应阈值(均值)', img_Z_M)
cv2.imshow('自适应阈值(高斯)', img_Z_G)
cv2.imshow('大津法', img_D)
cv2.imshow('高斯大津法', img_G_D)

hist_0 = cv2.calcHist([img], [0], None, [256], [0, 300])
hist_1 = cv2.calcHist([img_G], [0], None, [256], [0, 300])
plt.subplot(2, 1, 1)
plt.plot(hist_0, 'b')
plt.subplot(2, 1, 2)
plt.plot(hist_1, 'r')
plt.show()


cv2.waitKey(0)
cv2.destroyAllWindows()

在这里插入图片描述

https://www.bilibili.com/video/BV1vr4y1E7fW/?spm_id_from=333.788&vd_source=b89ce2a9b55dab86caa0ee60b66c9f86

https://www.bilibili.com/video/BV1pB4y1p7Ak/?p=15&spm_id_from=pageDriver&vd_source=b89ce2a9b55dab86caa0ee60b66c9f86

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 使用OpenCV库可以很方便地实现固定阈值分割算法。下面是一个示例代码: ```python import cv2 # 读取图像,使用灰度模式 img = cv2.imread('image.jpg', cv2.IMREAD_GRAYSCALE) # 选定阈值 threshold = 127 # 对图像进行分割 ret, binary = cv2.threshold(img, threshold, 255, cv2.THRESH_BINARY) # 显示分割结果 cv2.imshow('binary', binary) cv2.waitKey(0) cv2.destroyAllWindows() ``` 首先使用cv2.imread函数读取图像,并使用cv2.IMREAD_GRAYSCALE模式将图像转换成灰度图像。然后选定阈值,使用cv2.threshold函数对图像进行分割,得到二值化图像。最后使用cv2.imshow函数显示分割结果,并使用cv2.waitKey和cv2.destroyAllWindows函数等待用户按下键盘上的任意键,然后关闭所有窗口。 需要注意的是,如果图像路径不在当前工作目录下,需要使用绝对路径或相对路径来指定图像路径。另外,阈值的选取需要根据具体情况进行调整,以获得最佳的分割效果。 ### 回答2: OpenCV中的固定阈值分割算法是一种简单而常用的图像分割方法,其基本原理是将图像的像素值与预先设定的阈值进行比较,根据比较的结果将像素分为不同的区域。 编写固定阈值分割算法可以分为以下步骤: 1. 导入必要的库文件,包括OpenCV库和相关的头文件。 2. 读取待分割的图像,可以使用OpenCV提供的函数`cv::imread()`。 3. 对图像进行预处理,例如转换为灰度图像,可以使用OpenCV提供的函数`cv::cvtColor()`。 4. 根据应用的需求,选择合适的阈值类型,包括二进制阈值、反二进制阈值、截断阈值等等。 5. 通过调用OpenCV提供的函数`cv::threshold()`,将图像的像素值与设定的阈值进行比较,得到阈值分割的结果。 6. 可选的,对分割结果进行后处理,例如去除噪声,可以使用OpenCV提供的函数`cv::erode()`和`cv::dilate()`。 7. 输出分割结果图像,可以使用OpenCV提供的函数`cv::imwrite()`。 编写固定阈值分割算法的关键在于调用OpenCV提供的函数来实现图像处理的各个步骤,并根据具体应用的需求选择合适的参数和方法。需要注意的是,对于不同的图像和阈值选择,可能需要进行一定的调试和优化才能得到最好的分割效果。 ### 回答3: Opencv是一个开源的计算机视觉库,提供了许多图像处理和图像分割的功能。固定阈值分割算法是一种常用的图像分割方法,其基本思想是将图像根据像素的灰度值与设定的阈值进行比较,将像素值大于阈值的部分设置为一个固定值,小于阈值的部分设置为另一个固定值,从而将图像分成两部分。 在Opencv中,可以使用函数`threshold`来实现固定阈值分割算法。该函数的原型如下: ``` threshold(InputArray src, OutputArray dst, double thresh, double maxval, int type); ``` 其中,`src`是输入图像,`dst`是输出图像,`thresh`是设定的阈值,`maxval`是设定的最大值,`type`是阈值分割的类型,有多种选项。 例如,假设我们要将一张彩色图像进行固定阈值分割,设定阈值为100,将大于100的部分设置为255,小于100的部分设置为0,可以使用以下代码实现: ```python import cv2 # 读取图片 img = cv2.imread('image.jpg', 0) # 创建输出图像 dst = np.zeros_like(img) # 阈值分割 threshold_value = 100 max_value = 255 cv2.threshold(img, threshold_value, max_value, cv2.THRESH_BINARY, dst) # 在窗口中显示结果 cv2.imshow('Threshold Image', dst) cv2.waitKey(0) cv2.destroyAllWindows() ``` 以上就是使用Opencv编写固定阈值分割算法的简单示例。通过这个方法,我们可以对图像进行二值化处理,得到分割后的结果,从而便于后续的图像处理和分析任务。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值