作用:
1.计算一维向量卷积
u = [1 1 1];
v = [1 1 0 0 0 1 1];
w = conv(u,v)
2.通过卷积计算多项式乘法
u = [1 0 1];
v = [2 7];
w = conv(u,v)
作用:一维数字滤波器
y = filter(b,a,x) 使用由分子和分母系数 b 和 a 定义的有理传递函数 对输入数据 x 进行滤波。
// 移动平均滤波器是用于对含噪数据进行平滑处理的常用方法。
t = linspace(-pi,pi,100);
rng default %initialize random number generator
x = sin(t) + 0.25*rand(size(t));
windowSize = 5;
b = (1/windowSize)*ones(1,windowSize);
a = 1;
y = filter(b,a,x);
plot(t,x)
hold on
plot(t,y)
legend('Input Data','Filtered Data')
作用:二维卷积
A = rand(3);
B = rand(4);
C = conv2(A,B)
conv2函数
1、用法
C=conv2(A,B,shape); %卷积滤波
A:输入图像,B:卷积核
假设输入图像A大小为ma x na,卷积核B大小为mb x nb,则
当shape=full时,返回全部二维卷积结果,即返回C的大小为(ma+mb-1)x(na+nb-1)
shape=same时,返回与A同样大小的卷积中心部分
shape=valid时,不考虑边界补零,即只要有边界补出的零参与运算的都舍去,返回C的大小为(ma-mb+1)x(na-nb+1)
2、实现步骤
假设输入图像A大小为ma x na,卷积核大小为mb x nb,则MATLAB的conv2函数实现流程如下:
a、对输入图像补零,第一行之前和最后一行之后都补mb-1行,第一列之前和最后一列之后都补nb-1列(注意conv2不支持其他的边界补充选项,函数内部对输入总是补零)。
b、关于卷积核的中心,旋转卷积核180度。
c、滑动卷积核,将卷积核的中心位于图像矩阵的每一个元素。
d、将旋转后的卷积核乘以对应的矩阵元素再求和。
1、用法
B = filter2(h,A,shape) ; %相关(correlation)滤波
2、实现步骤
假设输入图像A大小为ma x na,相关核h大小为mb x nb,MATLAB的filter2的实现流程如下:
注意filter2不对核进行180°旋转,直接对应相乘再相加,这一点与conv2不同。
1、用法
B=imfilter(A,H,option1,option2,option3);
A:输入图像,H:滤波核
2、优势:
Padding Options 填充选项
1)默认补0
2)symmetric 对称:数组边界之外的输入数组值是通过沿数组边界对数组进行镜面反射得到
3)replicate 复制:数组边界之外的输入数组值假定为等于最近的数组边界值
.
4)circular 循环:数组边界之外的输入数组值是通过隐式假设输入数组具有周期性来计算的。
Output Size 输出大小
same:输出数组与输入数组大小相同。这是未指定输出大小选项时的默认行为。
full:输出数组是完全滤波后的结果,因此比输入数组大。
作用:构造卷积核,可以与filter2、conv2和imfilter配合使用
h = fspecial(type)
h = fspecial('average',hsize)
h = fspecial('disk',radius)
h = fspecial('gaussian',hsize,sigma)
h = fspecial('laplacian',alpha)
h = fspecial('log',hsize,sigma)
h = fspecial('motion',len,theta)
h = fspecial('prewitt')
h = fspecial('sobel')
filter2、conv2将输入转换为double类型,输出也是double的,输入总是补零(zero padded), 不支持其他的边界补充选项。
imfilter:不将输入转换为double,输出只与输入同类型,有灵活的边界补充选项。建议使用~
MATLAB代码:
clear;
close all;
clc;
%% fspecial函数
value = 5;
h = fspecial('gaussian',[5 5],value);
srcImage = imread('lena.jpg');
srcImage = rgb2gray(srcImage);
srcImage_double = double(srcImage);
%% conv2函数 默认:'full',只能补零
image_conv2 = conv2(srcImage_double,h);
%% filter2函数 默认:'same',只能补零
image_filter2 = filter2(h,srcImage_double);
%% imfilter函数 默认:'same'
image_imfilter = imfilter(srcImage,h,'replicate');
%% 显示图像
figure(1);
subplot(221);imshow(srcImage,[]); title('原图');
subplot(222);imshow(image_conv2,[]); title('conv2');
subplot(223);imshow(image_filter2,[]); title('filter2');
subplot(224);imshow(image_imfilter,[]); title('imfilter');