OpenCV学习笔记(8)——图像平滑
- 使用不同的低筒滤波器对图像进行模糊
- 使用自定义的率弄起对图像进行卷积(2D卷积)
2D卷积
与信号一样,我们也可以对2D图像实施低通滤波,高通滤波等。LPF帮助我们去除噪声,模糊图像。而HPF帮助我们找到图像边缘。
OpenCV提供的函数cv2.filter2D()可以让我们对一幅图像进行卷积操作。比如下面我们将对一幅图像使用平均滤波器,如一个5*5的平均滤波器核:

操作如下:将核放在图像的一个像素A上,求与核对应的图像上的25个像素的和,再取平均数,用这个平均数代替像素A的值。重复以上操作直到将图像的每一个像素值都更新一边。例程如下:
# -*- coding:utf-8 -*- import numpy as np
import cv2
from matplotlib import pyplot as plt img = cv2.imread('2.jpg') kernel = np.ones((5,5),np.float32)/25 #cv2.filter2D(src,depth,kernel,...)
#那个depth暂时没看出有啥用,试了几个值都没区别
dst = cv2.filter2D(img,-1,kernel) cv2.imshow('ori',img)
cv2.imshow('avr',dst) cv2.waitKey(0)
cv2.destroyAllWindows()
---> 
图像模糊(图像平滑)
使用低通滤波器可以达到图像模糊的目的。这对去除噪声很有帮助。其实就是去掉图像中的高频部分(比如:噪声,边界)。所以边界也会被模糊一点(当然也存在一些不会模糊掉边界的技术)。OpenCV中提供了四种模糊技术。
1.平均
其实和前面是一样的,但是实现方法不一样,他是用卷积框覆盖区域所有像素的平均值来代替中心元素。可以使用cv2.blur() 和 cv2.boxFilter()来完成。我们需要设定卷积框的宽和高。如下面一个3*3的归一化卷积框:

# -*- coding:utf-8 -*- import numpy as np
import cv2
from matplotlib import pyplot as plt img = cv2.imread('2.jpg') blur = cv2.blur(img,(3,3))如果改为5*5应该会得到和前面一样的效果
#如果不想用归一化卷积框,可以用blur = cv2.boxFilter(src,depth,size,...)并传入参数normalize=False #由于用plt读入BGR图会出问题,所以改用cv2
cv2.imshow('ori',img)
cv2.imshow('avr',blur) cv2.waitKey(0)
cv2.destroyAllWindows()
2.高斯模糊
现在把卷积核换成高斯核(简单来说,方框不变,原来每个方框里的值是相等的,现在变成高斯分布的,方框中心的值最大,其余方框根据距离中心元素的距离递减,构成一个高斯小山包。这样原来的求平均变成了加权平均,权值就是框里的值)。实现的函数是cv2.GaussianBlur()。我们需要制定高斯核的宽和高(必须是奇数)。以及高斯函数眼X,Y方向的标准差。如果我们只指定了X方向的标准差,Y方向也会取相同值。如果两个标准差均为0,那么函数会根据核函数的大小自己计算。高斯滤波可以有效的从图像中去除高斯噪声。
也可以用cv2.getGaussianKernel()自己构建一个高斯核。
可以将高斯模糊应用于开始的例子中:
# -*- coding:utf-8 -*-
import numpy as np
import cv2
from matplotlib import pyplot as plt
img = cv2.imread('2.jpg')
blur = cv2.GaussianBlur(img,(5,5),0)
#由于用plt读入BGR图会出问题,所以改用cv2
cv2.imshow('ori',img)
cv2.imshow('avr',blur)
cv2.waitKey(0)
cv2.destroyAllWindows()
效果如下
---> 
3.中值模糊
顾名思义就是用与卷积框对应像素的中值来替代中心像素的值。这个滤波器经常用来去除椒盐噪声。前面的滤波器都是用计算得到的一个新值来取代中心像素的值,而中值滤波是用中心像素周围的值来取代他。他能有效的去除噪声,卷积核的大小也必须是一个奇数(否则哪来的中心)
我们可以在原图上加上50%的噪声在使用中值模糊。
# -*- coding:utf-8 -*- import numpy as np
import cv2
from matplotlib import pyplot as plt img = cv2.imread('6.jpg') blur = cv2.medianBlur(img,5) #由于用plt读入BGR图会出问题,所以改用cv2
cv2.imshow('ori',img)
cv2.imshow('avr',blur) cv2.waitKey(0)
cv2.destroyAllWindows()
---> 
4.双边滤波
cv2.bilateralFilter()能在保持边界清晰的情况下有效的去除噪声。但是这种操作与其他滤波器相比会比较慢。双边滤波和前述的滤波不同,他同时使用空间高斯权重和灰度值相似性高斯权重。空间高斯函数确保只有邻近区域的像素对中心点有影响,灰度值相似性高斯函数确保只有与中心像素灰度值相近的才会被用来模糊运算。所以这种方法会确保边界不会被模糊掉,因为边界处的灰度值变化比较大。
进行双边滤波的代码如下:
# -*- coding:utf-8 -*- import numpy as np
import cv2
from matplotlib import pyplot as plt img = cv2.imread('2.jpg') #cv2.bilateralFilter(src,d,sigmaColor,sigmaSpace),d是邻域直径,两个75分别し空间高斯函数标准差,灰度值相似性高斯函数标准差
blur = cv2.bilateralFilter(img,9,75,75) #由于用plt读入BGR图会出问题,所以改用cv2
cv2.imshow('ori',img)
cv2.imshow('avr',blur) cv2.waitKey(0)
cv2.destroyAllWindows()
效果如下:
---> 
OpenCV学习笔记(8)——图像平滑的更多相关文章
- opencv学习笔记(四)--图像平滑处理
图像平滑处理的几种常用方法: 均值滤波 归一化滤波 高斯模糊 中值滤波 平滑处理(模糊)的主要目的是去燥声: 不同的处理方式适合不同的噪声图像,其中高斯模糊最常用. 其实最重要的是对图像卷积的核的理解 ...
- OpenCV学习笔记3
OpenCV学习笔记3 图像平滑(低通滤波) 使用低通滤波器可以达到图像模糊的目的.这对与去除噪音很有帮助.其实就是去除图像中的高频成分(比如:噪音,边界).所以边界也会被模糊一点.(当然,也有一些模 ...
- opencv学习笔记(七)SVM+HOG
opencv学习笔记(七)SVM+HOG 一.简介 方向梯度直方图(Histogram of Oriented Gradient,HOG)特征是一种在计算机视觉和图像处理中用来进行物体检测的特征描述子 ...
- opencv学习笔记(六)直方图比较图片相似度
opencv学习笔记(六)直方图比较图片相似度 opencv提供了API来比较图片的相似程度,使我们很简单的就能对2个图片进行比较,这就是直方图的比较,直方图英文是histogram, 原理就是就是将 ...
- opencv学习笔记(五)镜像对称
opencv学习笔记(五)镜像对称 设图像的宽度为width,长度为height.(x,y)为变换后的坐标,(x0,y0)为原图像的坐标. 水平镜像变换: 代码实现: #include <ios ...
- opencv学习笔记(四)投影
opencv学习笔记(四)投影 任选了一张图片用于测试,图片如下所示: #include <cv.h> #include <highgui.h> using namespace ...
- opencv学习笔记(三)基本数据类型
opencv学习笔记(三)基本数据类型 类:DataType 将C++数据类型转换为对应的opencv数据类型 OpenCV原始数据类型的特征模版.OpenCV的原始数据类型包括unsigned ch ...
- opencv学习笔记(二)寻找轮廓
opencv学习笔记(二)寻找轮廓 opencv中使用findContours函数来查找轮廓,这个函数的原型为: void findContours(InputOutputArray image, O ...
- opencv学习笔记(一)IplImage, CvMat, Mat 的关系
opencv学习笔记(一)IplImage, CvMat, Mat 的关系 opencv中常见的与图像操作有关的数据容器有Mat,cvMat和IplImage,这三种类型都可以代表和显示图像,但是,M ...
随机推荐
- js单选和全选
列子: //拿到选中的单选框 一.var objs = $(".detail") for(var obj in objs){ var isCheck = obj.is(':chec ...
- java的移位和异或运算
Java移位运算种类 基础:我们知道在Java中int类型占32位,可以表示一个正数,也可以表示一个负数.正数换算成二进制后的最高位为0,负数的二进制最高为为1 例子: -5换算成二进制后为:1111 ...
- Woobuntu
Wooyun + Ubuntu = Woobuntu Woobuntu是基于Ubuntu系统的一款安全研究环境配置工具,可以自动安装并配置众多的安全工具与依赖环境,此外还针对中国用户的习惯进行了一些优 ...
- linux上安装rz和sz
简介 lrzsz 官网入口:http://freecode.com/projects/lrzsz/ lrzsz是一个unix通信套件提供的X,Y,和ZModem文件传输协议 windows 需要向ce ...
- SpringMVC获取HttpClient 请求的数据
package com.nnk.upstream.controller;import org.springframework.util.StreamUtils;import javax.servlet ...
- SVN 安装教程
安装包:http://pan.baidu.com/s/1kTTcbJp 安装步骤看这个博主的就好了: http://www.cnblogs.com/xing901022/p/4399382.html ...
- dedecms织梦移站后替换数据库中文件路径命令
1.系统设置路径替换 update dede_sysconfig set value='http://afish.cnblogs.com' where varname='cfg_basehost'; ...
- 最长回文子串(动规,中心扩散法,Manacher算法)
题目 leetcode:5. Longest Palindromic Substring 解法 动态规划 时间复杂度\(O(n^2)\),空间复杂度\(O(n^2)\) 基本解法直接看代码 class ...
- GO (待更新)
日期20190531,GO AND TOOLS FOR HOME 0 环境搭建 https://golang.org/dl/ Install the Go tools If you are upgr ...
- 更新protobuf
sudo pip install --upgrade protobuf sudo apt-get install libprotobuf-dev protobuf-compiler这个不知道是什么问题 ...