MATLAB,中值滤波代码
时间: 2023-08-06 21:16:50 浏览: 115
MATLAB 中值滤波的代码如下:
```matlab
% 读入图像
img = imread('lena.png');
% 中值滤波
filtered_img = medfilt2(img, [3, 3]); % 3x3 的窗口
% 显示结果
subplot(1, 2, 1), imshow(img), title('原图像');
subplot(1, 2, 2), imshow(filtered_img), title('中值滤波后的图像');
```
其中,`medfilt2` 函数用于执行二维中值滤波,第一个参数是输入图像,第二个参数是滤波器的大小,可以是一个标量或一个二元向量。这里我们使用了一个 3x3 的窗口进行滤波。然后利用 `subplot` 和 `imshow` 函数将原图像和滤波后的图像显示在同一张图像上。
相关问题
matlab 中值滤波代码
MATLAB 中可以使用 medfilt2 函数实现二维中值滤波,示例代码如下:
```matlab
% 读取图像
I = imread('lena.png');
% 添加椒盐噪声
J = imnoise(I, 'salt & pepper', 0.02);
% 中值滤波
K = medfilt2(J);
% 显示结果
subplot(1, 2, 1), imshow(J), title('添加噪声的图像');
subplot(1, 2, 2), imshow(K), title('中值滤波后的图像');
```
上述代码中,首先读取一张图像并添加椒盐噪声,然后使用 medfilt2 函数进行中值滤波,最后显示原图和处理后的图像。其中,medfilt2 函数的参数可以指定滤波器的大小,例如:
```matlab
K = medfilt2(J, [3 3]); % 3x3 的滤波器
```
这将使用 3x3 的滤波器进行中值滤波。
matlab中值滤波代码
以下是MATLAB中的一个简单的中值滤波器实现代码:
```matlab
function img_filtered = median_filter(img, kernel_size)
% img: 输入图像
% kernel_size: 滤波器的大小
% img_filtered: 滤波后的图像
[m, n] = size(img);
img_filtered = zeros(m, n);
% 补0操作,使得滤波器能够作用于图像边缘
img_padded = padarray(img, [floor(kernel_size/2), floor(kernel_size/2)], 'symmetric');
for i = 1:m
for j = 1:n
% 取出 kernel_size x kernel_size 的邻域
neighborhood = img_padded(i:i+kernel_size-1, j:j+kernel_size-1);
% 计算邻域中像素的中值
img_filtered(i, j) = median(neighborhood(:));
end
end
end
```
这个函数实现了一个基本的中值滤波器,输入图像img和滤波器的大小kernel_size,输出滤波后的图像img_filtered。这个代码使用了一个嵌套的for循环来遍历整个图像并计算每个像素的中值。为了能够在图像边缘正确地进行滤波操作,图像被用symmetric方式进行填充。
阅读全文