zoukankan      html  css  js  c++  java
  • opencv之图像阈值化处理

    一、函数简介

    1、threshold—图像简单阈值化处理

    函数原型:threshold(src, thresh, maxval, type, dst=None)

    src:图像矩阵

    thresh:阈值

    maxVal:像素最大值

    type:阈值化类型

    2、adaptiveThreshold—图像自适应阈值化处理

    函数原型:adaptiveThreshold(src, maxValue, adaptiveMethod, thresholdType, blockSize, C, dst=None)

    src:图像矩阵

    maxValue:像素最大值

    adaptiveMethod:自适应方法

    thresholdType:阈值化类型

    blockSize:窗口尺寸

    C:为一整数,减去该整数来对阈值进行微调

    3、thresholding.otsu—图像最大类间方差阈值化处理

    函数原型:thresholding.otsu(src)

    src:图像矩阵

    4、thresholding.rc—图像Riddler-Calvard阈值化处理

    函数原型:thresholding.rc(src)

    src:图像矩阵

    二、实例演练

    1、图像二值化及反转

    代码如下:

    #encoding:utf-8
    
    #
    #图像二值化及反转
    #
    
    import numpy as np
    import cv2
    
    image = cv2.imread("H:\img\coins.bmp")
    image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)#将图像转为灰色
    blurred = cv2.GaussianBlur(image, (5, 5), 0)#高斯滤波
    cv2.imshow("Image", image)#显示图像
    (T, thresh) = cv2.threshold(blurred, 155, 255, cv2.THRESH_BINARY)#阈值化处理,阈值为:155
    cv2.imshow("Threshold Binary", thresh)
    
    (T, threshInv) = cv2.threshold(blurred, 155, 255, cv2.THRESH_BINARY_INV)#反阈值化处理,阈值为:155
    cv2.imshow("Threshold Binary Inverse", threshInv)
    
    #cv2.imshow("Coins", cv2.bitwise_and(image, image, mask =threshInv))
    cv2.waitKey(0)
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    结果如下:

    原图像:

    这里写图片描述

    二值化图像:

    这里写图片描述

    二值化反转图像:

    这里写图片描述

    2、图像自适应阈值化

    代码如下:

    #encoding:utf-8
    
    #
    #自适应阈值化处理
    #
    
    import numpy as np
    import cv2
    
    image = cv2.imread("H:\img\lena.jpg")#读取图像
    image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)#将图像转化为灰度
    blurred = cv2.GaussianBlur(image, (5, 5), 0)#高斯滤波
    cv2.imshow("Image", image)
    
    #自适应阈值化处理
    #cv2.ADAPTIVE_THRESH_MEAN_C:计算邻域均值作为阈值
    thresh = cv2.adaptiveThreshold(blurred, 255,cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY_INV, 11, 4)
    cv2.imshow("Mean Thresh", thresh)
    #cv2.ADAPTIVE_THRESH_GAUSSIAN_C:计算邻域加权平均作为阈值
    thresh = cv2.adaptiveThreshold(blurred, 255,cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY_INV, 15, 3)
    cv2.imshow("Gaussian Thresh", thresh)
    cv2.waitKey(0)
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    结果如下:

    原图像:

    这里写图片描述

    自适应阈值—邻域均值:

    这里写图片描述

    自适应阈值—邻域加权平均:

    这里写图片描述

    3、最大类间方差阈值化

    代码如下:

    #encoding:utf-8
    
    #
    #最大类间方差法
    #
    import numpy as np
    import cv2
    import mahotas
    #载入图像
    image = cv2.imread("H:\img\lena.jpg") #读入图像
    cv2.imshow("Original",image)#显示原图像
    cv2.waitKey()#程序暂停
    
    #对图像进行高斯滤波
    image = cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)#将原图像转化为灰度图像
    blurred = cv2.GaussianBlur(image,(5,5),0)#高斯滤波
    cv2.imshow("Image",image)#显示图像
    cv2.waitKey()
    
    #Otsu's threshold法
    T = mahotas.thresholding.otsu(blurred)##最大类间方差法求阈值,T为阈值
    print "Otsu's threshold:%d" %(T)#打印阈值
    thresh = image.copy()#复制图像:image(矩阵)
    thresh[thresh >T] = 255#矩阵thresh中>T的值赋值为255
    thresh[thresh < 255] = 0#矩阵thresh中<255的值赋值为0
    thresh = cv2.bitwise_not(thresh)#thresh取反
    cv2.imshow("Otsu",thresh)#显示图像
    cv2.waitKey()
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28

    结果如下:

    原图像:

    这里写图片描述

    最大类间方差阈值化:

    这里写图片描述

    4、Riddler-Calvard方法

    代码如下:

    #encoding:utf-8
    
    #
    #最大类间方差法
    #
    
    import numpy as np
    import cv2
    import mahotas
    
    #载入图像
    image = cv2.imread("H:\img\lena.jpg") #读入图像
    cv2.imshow("Original",image)#显示原图像
    cv2.waitKey()#程序暂停
    
    #对图像进行高斯滤波
    image = cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)#将原图像转化为灰度图像
    blurred = cv2.GaussianBlur(image,(5,5),0)#高斯滤波
    cv2.imshow("Image",image)#显示图像
    cv2.waitKey()
    
    #Riddler-Calvard方法
    T = mahotas.thresholding.rc(blurred)#用Riddler-Calvard法求阈值
    print "Riddler-Calvard:%d" %(T)#打印阈值
    thresh = image.copy()#复制图像:image(矩阵)
    thresh[thresh >T] = 255#矩阵thresh中>T的值赋值为255
    thresh[thresh < 255] = 0#矩阵thresh中<255的值赋值为0
    thresh = cv2.bitwise_not(thresh)#thresh取反
    cv2.imshow("Riddler-Calvard",thresh)#显示图像
    cv2.waitKey()
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30

    结果如下:

    原图像:

    这里写图片描述

    Riddler-Calvard方法:

    这里写图片描述


    转载自:http://blog.csdn.net/jnulzl/article/details/47753433


  • 相关阅读:
    day29
    day28
    day27
    查询区间内有多少个不同的数(线段树/树状数组)
    树状数组变形:带区间修改的树状数组
    特征提取:PCA主成分分析法和NMF非负矩阵分解法
    Trie树
    Logistic&Softmax回归
    高斯贝叶斯分类器(GNB实战)
    朴素贝叶斯分类器(伯努利贝叶斯+高斯贝叶斯+多项式贝叶斯)
  • 原文地址:https://www.cnblogs.com/blogwangwang/p/9608147.html
Copyright © 2011-2022 走看看