MATALAB图像去噪中值滤波的实现代码
时间: 2023-10-26 09:10:32 浏览: 36
MATLAB 中的中值滤波可以使用 `medfilt2` 函数实现,具体代码如下:
```matlab
% 读入图像
img = imread('test.jpg');
% 添加噪声(这里以椒盐噪声为例)
noisy_img = imnoise(img, 'salt & pepper', 0.02);
% 中值滤波
filtered_img = medfilt2(noisy_img, [3, 3]);
% 显示结果
figure;
subplot(1, 2, 1);
imshow(noisy_img);
title('Noisy Image');
subplot(1, 2, 2);
imshow(filtered_img);
title('Filtered Image');
```
上述代码中,我们首先读入一张图像,并添加了椒盐噪声。然后使用 `medfilt2` 函数对噪声图像进行中值滤波,指定滤波器大小为 $3\times3$。最后将原图像和滤波后的图像在两个子图中显示出来。
相关问题
matlab 图像去噪中值滤波代码
以下是使用MATLAB进行图像去噪的中值滤波的代码示例[^2]:
```matlab
% 读取图像
image = imread('input_image.jpg');
% 将图像转换为灰度图像
gray_image = rgb2gray(image);
% 对图像进行中值滤波
filtered_image = medfilt2(gray_image);
% 显示原始图像和去噪后的图像
subplot(1, 2, 1);
imshow(gray_image);
title('原始图像');
subplot(1, 2, 2);
imshow(filtered_image);
title('中值滤波后的图像');
```
请注意,这只是一个简单的示例代码,你需要将`input_image.jpg`替换为你自己的图像文件名,并确保图像文件与代码文件在同一目录下。
matlab图像去噪中值滤波
Matlab中可以使用medfilt2函数来进行中值滤波处理,该函数的语法格式如下:
```
B = medfilt2(A, [m n])
```
其中,A为需要进行中值滤波处理的原始图像,[m n]为中值滤波器的大小,通常为奇数,表示中心像素周围的像素个数。
下面是一个示例代码:
```
I = imread('lena.png');
J = imnoise(I,'salt & pepper',0.02);
K = medfilt2(J,[3 3]);
subplot(1,3,1),imshow(I),title('原始图像');
subplot(1,3,2),imshow(J),title('加噪声图像');
subplot(1,3,3),imshow(K),title('中值滤波处理图像');
```
其中,第一行代码读入了一张lena.png图像,第二行代码在图像上添加了0.02的椒盐噪声,第三行代码使用3x3的中值滤波器对图像进行中值滤波处理,最后使用subplot函数将原始图像、加噪声图像和中值滤波处理后的图像分别显示出来。
需要注意的是,中值滤波适用于去除椒盐噪声等随机噪声,而对于高斯噪声等其他类型的噪声效果并不好。