python opencv数字图像处理TASK2灰度变换和二值化

灰度变换和二值化
1、灰度化的常用方法
在数字图像处理中常用的灰度化方法主要包括:分量法、加权平均值和最大值法。一般认为三种方法并无优劣之分,在不同情况下增加一些尝试方法,兴许会有不用效果。
以下主要介绍灰度化和灰度变换:
灰度化

import cv2 as cv

img = cv.imread('peppers.png')
cv.imshow('input',img)
grayimg=cv.cvtColor(img,cv.COLOR_BGR2GRAY)
cv.imshow('gray',grayimg)
cv.waitKey(0)
cv.destroyAllWindows()

效果对比如下:
效果对
2、灰度变换:反转、对数变化、幂律变化、分段性变换
反转

import cv2 as cv

img = cv.imread('peppers.png')
#获取宽和高
rows=img.shape[0]
cols=img.shape[1]
cv.imshow('input',img)
grayimg=cv.cvtColor(img,cv.COLOR_BGR2GRAY)
cv.imshow('gray',grayimg)
#进行反转
gray1=grayimg.copy()
for i in range(rows):
    for j in range(cols):
        gray1[i][j]=255-gray1[i][j]
cv.imshow('fanzhuan',gray1)
cv.waitKey(0)
cv.destroyAllWindows()

效果对比如下:
在这里插入图片描述
对数:主要用来增强较暗的 细节

#对数变换
gray2=grayimg.copy()
for i in range(rows):
    for j in range(cols):
        gray2[i][j] = 3 * math.log(1 + gray2[i][j])
cv.imshow('duishu',gray2)

效果对比如下
在这里插入图片描述
幂律变化又叫伽马变化:
伽马值小于1时,会拉伸图像中灰度级较低的区域,压缩灰度级较高的部分
伽马值大于1时,会拉伸图像中灰度级较高的区域,压缩灰度级较低的部

#幂律变化
gray3=grayimg.copy()
for i in range(rows):
    for j in range(cols):
        gray3[i][j]=0.5*pow(gray3[i][j],0.8)

效果如下
在这里插入图片描述
分段性变化:即在不同的区间采用不同变换,下面以125为分水岭,小于进行伽马变换,大于进行反转。

#分段变换
gray4=grayimg.copy()
for i in range(rows):
    for j in range(cols):
        if gray4[i][j]<125:
            gray4[i][j]=0.5*pow(gray4[i][j],0.8)
        else:
            gray4[i][j] = 255 - gray4[i][j]
cv.imshow('fenduan',gray4)

效果如下:图1为gray,图2为分段变换,图3为反转变换,图4为伽马变换。
在这里插入图片描述

3、图像直方图,直方图匹配
直方图像素值分布的统计信息

# 图像直方图
import cv2 as cv
import numpy as np
from matplotlib import pyplot as plt

#一维
def plot_demo(image):
    plt.hist(image.ravel(), 256, [0, 256])
    plt.show()
#三维
def image_hist(image):
    color = ('blue', 'green', 'red')
    for i, color in enumerate(color):
        hist = cv.calcHist([image], [i], None, [256], [0, 256])
        plt.plot(hist, color=color)
        plt.xlim([0, 256])
    plt.show()

src = cv.imread('peppers.png')
cv.imshow('input', src)
plot_demo(src)
image_hist(src)
cv.waitKey(0)

效果如下:
在这里插入图片描述
在这里插入图片描述
模板匹配

def template_demo():
    tpl = cv.imread('part.png')
    target = cv.imread('peppers.png')
    cv.imshow('sample', tpl)
    cv.imshow('target', target)
    methods = [cv.TM_SQDIFF_NORMED, cv.TM_CCORR_NORMED, cv.TM_CCOEFF_NORMED]
    th, tw = tpl.shape[:2]
    for md in methods:
        print(md)
        result = cv.matchTemplate(target, tpl, md)
        min_val, max_val, min_loc, max_loc = cv.minMaxLoc(result)
        if md == cv.TM_SQDIFF_NORMED:
            tl = min_loc

        else:
            tl = max_loc  # tl是矩形左上角位置
        br = (tl[0] + tw, tl[1] + th)  # 根据左上顶点,分别加上模板宽高,求出另外一个顶角坐标
        bt = (tl[0] + 0, tl[1] + th)

        print(tl, bt, br)
        cv.rectangle(target, tl, br, (0, 0, 255), 2)  # 两个坐标,颜色,线宽
        cv.imshow('match' + np.str(md), target)
template_demo()

效果如下:cv.TM_SQDIFF_NORMED, cv.TM_CCORR_NORMED, cv.TM_CCOEFF_NORMED对应三种不同的匹配方式。
在这里插入图片描述
4、二值化
分别以OTSU阈值法,局部阈值和平均阈值进行二值化

import cv2 as cv
import numpy as np

def threshold_demo(image):
    gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)
    ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)  # (原图,0,255,二值化|阈值计算方法)
    print('threshold value:%s' % ret)
    cv.imshow('binary', binary)
    cv.imwrite('binary2.jpg', binary)
# 局部阈值
def local_threshold(image):
    gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)
    binary = cv.adaptiveThreshold(gray, 255, cv.ADAPTIVE_THRESH_GAUSSIAN_C, cv.THRESH_BINARY, 25, 10)  # blocksize必须为奇数
    cv.imshow('local', binary)
    cv.imwrite('local.jpg', binary)

def custom_threshold(image):
    gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)
    h, w = image.shape[:2]
    m = np.reshape(gray, [1, w * h])  # 把gray变成一行n列的
    mean = m.sum() / (w * h)  # 计算像素均值
    ret, binary = cv.threshold(gray, mean, 255, cv.THRESH_BINARY)  # (原图,0,255,二值化|阈值计算方法)
    cv.imshow('mean', binary)
    cv.imwrite('mean.jpg', binary)

src = cv.imread('peppers.png')
cv.imshow('input', src)
threshold_demo(src)
local_threshold(src)
custom_threshold(src)
cv.waitKey(0)
cv.destroyAllWindows()

效果如下:
在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【课程简介】 本课程基于面向PythonOpenCV,以OpenCV的官方文档的知识脉络为主线,介绍了OpenCV函数的具体使用方法、函数所使用的算法的具体原理。 在介绍函数使用时,提供了大量的程序案例演示。 在介绍具体原理时,采用了通俗易懂的语言和贴近生活的示例来说明问题,尽量避免涉及过于复杂抽象的公式。 课程包含数字图像处理的常用知识点,覆盖面全,方便学员系统深入全面地掌握OpenCV。 【你将收获什么】 1.  掌握数字图像的在计算机内表示的方法和处理的基本原理。掌握数字图像的表示方法是进行图像处理的前提和基础,能够为后续的智能图像处理打下坚实基础。 2.  使用好OpenCV开源库对于提升工作效率具有很大的帮助。OpenCV是优秀的开源库,提供了大量的函数帮助我们提升工作效率。大多数情况下,我们直接调用函数就能够满足我们的需求。同时,它的函数具有较好的交互性,能够根据需要更好地掌控图像处理的具体细节。 3.  学习图像处理的常用算法。课程不仅介绍函数的具体使用,也介绍了常用算法的基本原理,帮助学习者更好地理解图像处理的基本逻辑、方法,快速入门图像处理领域。 【我将如何教你】 1)在“黑盒”和“白盒“之间取得平衡  可以将OpenCV看成“黑盒”,不用关心其函数是如何实现的。在需要实现某一个功能时,直接调用其对应的函数即可,像使用Photoshop的各种功能一样。也可以将OpenCV看成“白盒”,关注其每一个函数的具体实现,认真研究每一个函数的具体实现方法和实现细节。这两种方式都是学习图像处理的很好方式,但是大多数课程过于强调其中某一种,要么忽略了算法的实现、要么忽略了使用方法。本课程尽量将OpenCV在“黑盒”和“白盒”之间取得平衡。既介绍算法的原理和方法,又将重点放在如何调用函数上,让学习者能够更加游刃有余地在计算机视觉项目中使用OpenCV来解决具体的问题。 2)将枯燥的算法采用具体的案例介绍  在图像处理中,有大量的算法保证了图像处理的准确、高效。OpenCV将一些常用的算法进行了封装,我们可以直接调用OpenCV的函数来使用对应的算法。但是,深入地理解算法能够帮助学习者更好地使用OpenCV函数。本课程尝试抛弃传统的使用复杂公式介绍算法的形式,尽量通过简单、通俗易懂的生活中实例来帮助学习者理解算法的基本逻辑 3)案例驱动、强调实战 OpenCV是一个庞大的资源库,提供了非常多的函数帮助我们高效地处理问题。初学者使用OpenCV的最大困惑就是熟练地掌握了每一个函数的调用方法,但是在解决实际问题时,不知道具体应该使用哪个函数。本课程通过大量的具体案例帮助学习快速掌握每个函数的应用场景,快速掌握OpenCV的核心使用方法和技巧。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值