接上次的笔记,开始图像操作的第二段学习旅程~~~

图像的处理(一)

图像阈值

拿到一张图像,图像是由众多像素点组成的,我们要对每一个像素点的值进行判断,用像素点的值与阈值进行比较,对于大于或小于阈值分别做不同的处理。

ret,dist = cv2.threshold(src,thresh,maxval,type)

src:输入图,只能输入单通道图像,通常来说为灰度图

dist:输出图

thresh:阈值

maxval:当像素值超过了阈值(或者小于阈值,根据type来决定),所赋予的值

type:二值化操作的类型,包括以下5种类型:cv2.THRESH_BINARY;cv2.THRESH_BINARY_INV;cv2.THRESH_TRUNC;cv2.THRESH_TOZERO;cv2.THRESH_TOZERO_INV

cv2.THRESH_BINARY:超过阈值部分取maxval(最大值),否则取0

cv2.THRESH_BINARY_INV:THRESH_BINARY的反转,即超过阈值部分取0,否则取maxval(最大值)

cv2.THRESH_TRUNC:大于阈值部分设为阈值,否则不变

cv2.THRESH_TOZERO:大于阈值部分不改变,否则设为0

cv2.THRESH_TOZERO_INV:THRESH_TOZERO的反转

#图像阈值
import matplotlib.pyplot as plt
ret, thresh1 = cv2.threshold(img_gray,127,255,cv2.THRESH_BINARY)
ret, thresh2 = cv2.threshold(img_gray,127,255,cv2.THRESH_BINARY_INV)
ret, thresh3 = cv2.threshold(img_gray,127,255,cv2.THRESH_TRUNC)
ret, thresh4 = cv2.threshold(img_gray,127,255,cv2.THRESH_TOZERO)
ret, thresh5 = cv2.threshold(img_gray,127,255,cv2.THRESH_TOZERO_INV)title = ['Original Image','BINARY','BINARY_INV','TRUNC','TOZERO','TOZERO_INV']
images = [img,thresh1,thresh2,thresh3,thresh4,thresh5]
for i in range(6):plt.subplot(2,3,i + 1),plt.imshow(images[i],'gray')plt.title(title[i])plt.xticks()plt.yticks()
plt.show()

图像平滑

当前输入数据,如上lena图像上有很多噪音点,现在我们想通过滤波、平滑处理等操作尽可能的去掉这些噪音点。

#图像平滑
img = cv2.imread('lenaNoise.png')
cv2.imshow('image',img)
cv2.waitKey(0)
cv2.destroyAllWindows()#均值滤波
#简单的平均卷积操作
blur = cv2.blur(img,(3,3))
cv2.imshow('blur',blur)
cv2.waitKey(0)
cv2.destroyAllWindows()#方框滤波
#基本和滤波一样,可以选择归一化
box = cv2.boxFilter(img,-1,(3,3),normalize=True)
cv2.imshow('box',box)
cv2.waitKey(0)
cv2.destroyAllWindows()#方框滤波
#基本和滤波一样,可以选择归一化,容易越界
box = cv2.boxFilter(img,-1,(3,3),normalize=False)
cv2.imshow('box',box)
cv2.waitKey(0)
cv2.destroyAllWindows()#高斯滤波
#高斯模糊的卷积核里的数值是满足高斯分布的,相当于更重视中间的
aussian = cv2.GaussianBlur(img,(5,5),1)
cv2.imshow('aussian',aussian)
cv2.waitKey(0)
cv2.destroyAllWindows()#中值滤波
#相当于用中值代替,利用中值滤波处理后,椒盐噪声几乎完全被去除掉
median = cv2.medianBlur(img,5)
cv2.imshow('median',median)
cv2.waitKey(0)
cv2.destroyAllWindows()#展示所有的
res = np.hstack((blur,aussian,median))
print(res)
cv2.imshow('median vs average',res)
cv2.waitKey(0)
cv2.destroyAllWindows()

均值滤波相当于低通滤波,有将图像模糊化的趋势,对椒盐噪声计基本无能为力。中值滤波的优点是可以很好的过滤掉椒盐噪声,缺点是易造成图像的不连续性。

形态学-腐蚀操作

#形态学—腐蚀操作
img = cv2.imread('dige.png')
cv2.imshow('image',img)
cv2.waitKey(0)
cv2.destroyAllWindows()kernel_1 = np.ones((3,3),np.uint8)
erosion = cv2.erode(img,kernel_1,iterations=1)
cv2.imshow('erosion',erosion)
cv2.waitKey(0)
cv2.destroyAllWindows()pie = cv2.imread('pie.png')
cv2.imshow('pie',pie)
cv2.waitKey(0)
cv2.destroyAllWindows()kernel_2 = np.ones((30,30),np.uint8)
erosion_1 = cv2.erode(pie,kernel_2,iterations=1)
erosion_2 = cv2.erode(pie,kernel_2,iterations=2)
erosion_3 = cv2.erode(pie,kernel_2,iterations=3)
res = np.hstack((erosion_1,erosion_2,erosion_3))
cv2.imshow('res',res)
cv2.waitKey(0)
cv2.destroyAllWindows()

形态学-膨胀操作

#形态学—膨胀操作
img = cv2.imread('dige.png')
cv2.imshow('image',img)
cv2.waitKey(0)
cv2.destroyAllWindows()kernel = np.ones((3,3),np.uint8)
dige_erosion = cv2.erode(img,kernel,iterations=1)
cv2.imshow('erosion',dige_erosion)
cv2.waitKey(0)
cv2.destroyAllWindows()kernel = np.ones((3,3),np.uint8)
dige_dilate = cv2.dilate(dige_erosion,kernel,iterations=1)
cv2.imshow('dilate',dige_dilate)
cv2.waitKey(0)
cv2.destroyAllWindows()pie = cv2.imread('pie.png')
kernel = np.ones((30,30),np.uint8)
dilate_1 = cv2.dilate(pie,kernel,iterations=1)
dilate_2 = cv2.dilate(pie,kernel,iterations=2)
dilate_3 = cv2.dilate(pie,kernel,iterations=3)
res = np.hstack((dilate_1,dilate_2,dilate_3))
cv2.imshow('res',res)
cv2.waitKey(0)
cv2.destroyAllWindows()

开运算与闭运算

开运算:先腐蚀,再膨胀

闭运算:先膨胀,再腐蚀

#开运算与闭运算
#开:先腐蚀,再膨胀
img = cv2.imread('dige.png')
kernel = np.ones((3,3),np.uint8)
opening = cv2.morphologyEx(img,cv2.MORPH_OPEN,kernel)
cv2.imshow('opening',opening)
cv2.waitKey(0)
cv2.destroyAllWindows()#闭:先膨胀,再腐蚀
img =cv2.imread('dige.png')
kernel = np.ones((3,3),np.uint8)
closing = cv2.morphologyEx(img,cv2.MORPH_CLOSE,kernel)
cv2.imshow('closing',closing)
cv2.waitKey(0)
cv2.destroyAllWindows()#梯度运算
#梯度=膨胀-腐蚀
pie = cv2.imread('pie.png')
kernel = np.ones((7,7),np.uint8)
dilate = cv2.dilate(pie,kernel,iterations=5)
erossion = cv2.erode(pie,kernel,iterations=5)res = np.hstack((dilate,erossion))
cv2.imshow('res',res)
cv2.waitKey(0)
cv2.destroyAllWindows()gradient = cv2.morphologyEx(pie,cv2.MORPH_GRADIENT,kernel)
cv2.imshow('gradient',gradient)
cv2.waitKey(0)
cv2.destroyAllWindows()#礼帽和黑帽
#礼帽=原始输入-开运算结果
#黑帽=闭运算-原始输入#礼帽
img = cv2.imread('dige.png')
kernel = np.ones((5,5),np.uint8)
tophat = cv2.morphologyEx(img,cv2.MORPH_TOPHAT,kernel)
cv2.imshow('topcat',tophat)
cv2.waitKey(0)
cv2.destroyAllWindows()
#黑帽
img = cv2.imread('dige.png')
kernel = np.ones((5,5),np.uint8)
blackhat = cv2.morphologyEx(img,cv2.MORPH_BLACKHAT,kernel)
cv2.imshow('blackhat',blackhat)
cv2.waitKey(0)
cv2.destroyAllWindows()

图像梯度-Sobel算子

梯度简单来说就是求导。OpenCV提供了三种不同的梯度滤波器,或者说高通滤波器:Sobel,Scharr和Lapacian。Sobel,Scharr其实就是求一阶或二阶导。Scharr是对Sobel的部分优化。Laplacian是求二阶导。

#图像梯度-Sobel算子
img = cv2.imread('pie.png',cv2.IMREAD_GRAYSCALE)
cv2.imshow('img',img)
cv2.waitKey(0)
cv2.destroyAllWindows()
dist = cv2.Sobel(src,ddepth,dx,dy,ksize)

ddepth:图像深度

dx和dy分别表示水平和竖直方向

ksize是Sobel算子的大小

#图像梯度-Sobel算子
img = cv2.imread('pie.png',cv2.IMREAD_GRAYSCALE)
cv2.imshow('img',img)
cv2.waitKey(0)
cv2.destroyAllWindows()def cv_show(img,name):cv2.imshow(name,img)cv2.waitKey(0)cv2.destroyAllWindows()#cv2.CV_64F,64F代表每一个像素点元素占64位浮点数
sobelx = cv2.Sobel(img,cv2.CV_64F,1,0,ksize=3)
sobelx = cv2.convertScaleAbs(sobelx)
cv_show(sobelx,'sobelx')#白到黑是正数,黑到白是负数,所有的负数都会被截断为0,所以要取绝对值
sobely = cv2.Sobel(img,cv2.CV_64F,1,0,ksize=3)
sobely = cv2.convertScaleAbs(sobely)
cv_show(sobely,'sobely')sobely = cv2.Sobel(img,cv2.CV_64F,0,1,ksize=3)
sobely = cv2.convertScaleAbs(sobely)
cv_show(sobely,'sobely')#分别计算x和y,再求和
sobelxy = cv2.addWeighted(sobelx,0.5,sobely,0.5,0)
cv_show(sobelxy,'sobelxy')img = cv2.imread('lena.jpg',cv2.IMREAD_GRAYSCALE)
sobelx = cv2.Sobel(img,cv2.CV_64F,1,0,ksize=3)
sobelx = cv2.convertScaleAbs(sobelx)
sobely = cv2.Sobel(img,cv2.CV_64F,0,1,ksize=3)
sobely = cv2.convertScaleAbs(sobely)
sobelxy = cv2.addWeighted(sobelx,0.5,sobely,0.5,0)
cv_show(sobelxy,'sobelxy')#整体计算存在重影,不建议
img = cv2.imread('lena.jpg',cv2.IMREAD_GRAYSCALE)
sobelxy = cv2.Sobel(img,cv2.CV_64F,1,1,ksize=3)
sobelxy = cv2.convertScaleAbs(sobelxy)
cv_show(sobelxy,'sobelxy')

图像梯度-Scharr算子

图像梯度-laplacian算子

拉普拉斯算子可以使用二阶导数的形式定义,可假设其离散实现类似于二阶Sobel导数。

#不同算子的差异
img = cv2.imread('lena.jpg',cv2.IMREAD_GRAYSCALE)
sobelx = cv2.Sobel(img,cv2.CV_64F,1,0,ksize=3)
sobely = cv2.Sobel(img,cv2.CV_64F,0,1,ksize=3)
sobelx = cv2.convertScaleAbs(sobelx)
sobely = cv2.convertScaleAbs(sobely)
sobelxy = cv2.addWeighted(sobelx,0.5,sobely,0.5,0)scharrx = cv2.Scharr(img,cv2.CV_64F,1,0)
scharry = cv2.Scharr(img,cv2.CV_64F,0,1)
scharrx = cv2.convertScaleAbs(scharrx)
scharry = cv2.convertScaleAbs(scharry)
scharrxy = cv2.addWeighted(scharrx,0.5,scharry,0.5,0)laplacian = cv2.Laplacian(img,cv2.CV_64F)
laplacian = cv2.convertScaleAbs(laplacian)res = np.hstack((img,sobelxy,scharrxy,laplacian))
cv_show(res,'res')

Opencv计算机视觉入门——图像的处理(一)相关推荐

  1. OpenCV计算机视觉(三) —— 图像的几何变换

    图像的几何变换主要包括图像的翻转.平移.旋转.透视以及一些镜像变换.主要是对图像的大小.位置.坐标进行操作,来实现图片的几何变换. 思维导图如下: 下面将针对这五个方面进行一一讲解. 图像的翻转 主要 ...

  2. 火山视窗opencv计算机视觉入门

    听他们说opencv以经在封装了,但是等了这么久都还没出来,所以自己找了些小例子过下瘾先. 由于本人水平有限,只能找来一些小玩意,看看能不能抛砖引玉,大家不要报太大的期望. 先发个简单的,其它的还在修 ...

  3. OpenCV计算机视觉编程之三种图像像素的遍历方法

    为了构建计算机视觉应用程序,需要学会访问图像内容,有时也要修改或创建图像,如何操作图像的像素,就需要遍历一幅图像并处理每一个像素.现在我们就来介绍OpenCV三种图像像素的遍历方法: 一. 用cv:: ...

  4. [Python图像处理] 三十五.OpenCV图像处理入门、算数逻辑运算与图像融合(推荐)

    该系列文章是讲解Python OpenCV图像处理知识,前期主要讲解图像入门.OpenCV基础用法,中期讲解图像处理的各种算法,包括图像锐化算子.图像增强技术.图像分割等,后期结合深度学习研究图像识别 ...

  5. [python opencv 计算机视觉零基础到实战] 六、图像运算

    一.学习目标 了解opencv中图像运算的方法 了解opencv中图像运算的运用 如有错误欢迎指出~ 二.了解OpenCV中图像运算的运用 目录 [python opencv 计算机视觉零基础到实战] ...

  6. OpenCV计算机视觉实战(Python版)_002图像基本操作

    OpenCV计算机视觉实战(Python版) https://www.bilibili.com/video/BV1ct411F7Te?p=2 数据读取-图像 cv2.IMREAD_COLOR:彩色图像 ...

  7. 计算机视觉入门之图像处理<六>:图像锐化处理

    往期文章回顾: 计算机视觉入门之<零> 计算机视觉入门之图像处理<一>:图像处理基础概念 计算机视觉入门之图像处理<二>:图像处理基础概念 计算机视觉入门之图像处理 ...

  8. OpenCV计算机视觉编程篇三《处理图像的颜色》

    前言 前期回顾: OpenCV计算机视觉编程篇二<操作像素> 上面这篇里面写了操作像素相关. 本章包括以下内容: 用策略设计模式比较颜色: 用 GrabCut 算法分割图像: 转换颜色表示 ...

  9. 【OpenCV图像处理入门学习教程四】基于LoG算子的图像边缘检测

    OpenCV图像处理入门学习教程系列,上一篇第三篇:基于SIFT特征和SURF特征的微旋转图像拼接与融合生成全景图像的比较 LoG边缘检测算子 LoG边缘检测算子是David Courtnay Mar ...

最新文章

  1. 科技基建,自主创芯——详解全球半导体制造行业格局
  2. 重新学.Net[二]——从编译到运行
  3. @suppressWarnings(unchecked)及其相关属性在Java中意思
  4. 开发经常犯的错误之→【join表连接关联查询 】
  5. CCF 2017-3-2 学生排队
  6. 破译密码、设计飞机和建设团队:Randy Shoup谈高绩效团队
  7. Matlab模拟液压缸运动,基于MATLAB-simulink的液压系统动态仿真(1).pptx
  8. 如何破解(免积分)下载百度文库+豆丁收费文档
  9. Sodinokibi勒索病毒利用Flash漏洞强势来袭
  10. 【沃顿商学院学习笔记】商业基础——Financing:02 年金 Annuity
  11. [HBase进阶]--rowkey设计要点(官方文档介绍)
  12. 简历这样写,大厂offer拿到手软
  13. 什么是物联网?有哪些应用?终于有人讲明白了
  14. 仿八大行星绕太阳3D旋转效果
  15. JAVA interrupt、interrupted和isInterrupted的区别
  16. 有趣的歌单昵称_抖音最火的10大神曲 你的歌单里面有几首
  17. java string长度字节_java String类型数据的字节长度
  18. html5 canvas烂漫的空中散落的花瓣动画特效
  19. 2. 网络协议及硬件
  20. 牛顿-莱布尼茨公式练习习题

热门文章

  1. 手机共享电脑的proxy网络
  2. (授人以鱼不如授人以渔)mysql-connector-java各种版本下载地址
  3. 用真实业务场景告诉你,高并发下如何设计数据库架构?
  4. C# 获取类的属性名
  5. HTMLCSS的语法与使用
  6. mui中拨打电话有两种方式:
  7. 在阿里云ACP认证考试中授权码有效期时限是多久?
  8. linux内核启动流程(文章最后流程图)
  9. AtCoder Beginner Contest 190 D - Staircase Sequences
  10. Python编程基础:用户输入若干个分数,求所有分数的平均分。每输入一个分数后询问是否继续输入下一个分数,回答“yes”就继续输入下一个分数,回答“no”就停止输入分数。