she*_*lbc 4 matlab image-processing filter
我不能为我的生活记住这个操作被称为什么.定义操作使得所考虑的像素被内核窗口中的最高频率的像素值替换.
目的是消除可能在其他更突出区域的边缘处发现的外来颜色,并巩固到较小的颜色子集.
例如,考虑刚果的旗帜:
如果我们放大到两种颜色之间的边界,我们会观察到颜色过渡效果.
就我的目的而言,上图中只有两种颜色,但对角线形状适合于边界颜色的混合.
这称为模式滤波器,因为您将用它的邻居的模式(或最常见的值)替换每个像素.
在MATLAB中,如果您有图像处理工具箱,则可以轻松执行此类过滤,使用colfilt该过滤将在指定大小的邻域内应用所提供的函数.
output = colfilt(data, [5 5], 'sliding', @mode)
Run Code Online (Sandbox Code Playgroud)
更新
如果您不想处理边缘处的所有零填充,您可以使用padarray向每侧应用3个像素的填充,然后执行过滤,然后从所有边缘移除额外的3个像素.
% Pad with replicates of the data
data = padarray(data, [3 3], 'replicate', 'both');
% Perform the filtering
new = colfilt(data, [5 5], 'sliding', @mode);
% Crop out the padding part
new = new(4:end-3,4:end-3);
Run Code Online (Sandbox Code Playgroud)
如果要将其推广到大小的内核,n可以使用以下函数:
function out = mode_filter(data, n)
pad_size = ceil(n / 2);
% Pad with replicates of the data
data = padarray(data, [pad_size, pad_size], 'replicate', 'both');
% Perform the filtering
out = colfilt(data, [n n], 'sliding', @mode);
% Crop out the padded part
out = out((pad_size + 1):(end - pad_size), (pad_size + 1):(end - pad_size));
end
Run Code Online (Sandbox Code Playgroud)