【问题标题】:matlab image smoothing with conv2matlab图像平滑与conv2
【发布时间】:2012-11-06 18:06:21
【问题描述】:

我是图像处理的新手,在实现图像平滑时发现了一些困难。

基本上,我有一个图像 A,我想用它的局部平均值替换所有像素。所以我定义了掩码 M1 = one(10) 并使用

 newImage = conv2(A, M1,'same')

它工作正常。但是在图像 A 中,完全由于噪声而存在毫无意义的像素,我不想将它们包括在平均中。我该怎么做,比如说有意义的像素是通过另一个蒙版 M2 定义的?

我在图像上做了一个简单的循环。它可以工作,但比 conv2() 慢得多。

for i = 1:self.row
    for j = 1:self.col
        if self.M2(i,j) % only treat meaningful pixels
            A(i,j) = self.createAvgPhasor(i,j);
        end
    end
end

    function [s_avg]=createAvgPhasor(self,m,n)
        % bound box along x 
        if m > self.rB
            xl = m - self.rB;
        else
            xl = 1;
        end
        if m < self.row_rB
            xu = m + self.rB;
        else
            xu = self.row;
        end
        % bound box along y 
        if n > self.rB
            yl = n - self.rB;
        else
            yl = 1;
        end
        if n < self.col_rB
            yu = n + self.rB;
        else
            yu = self.col;
        end
        M1 = false(self.row,self.col);
        M1(xl:xu,yl:yu) = true;
        msk = M1 & self.M2;
        s_avg = mean(self.Phi(msk));
    end

非常感谢您的帮助。

【问题讨论】:

  • 所以问题是你想用无意义的像素做什么?您想用平均值替换它们但不将它们包括在平均值中吗?你想让它们保持原样吗,用黑色代替它们......
  • 我不关心噪声像素的值。它们最终可以设置为 0。在平均中排除它们是我想要的。
  • 好的,我更新了我的答案,希望这会有所帮助,

标签: image matlab average convolution smoothing


【解决方案1】:

从卷积中排除坏点很容易。如果M2 包含一个1 代表您想要包含的像素,而一个0 代表您不包含的像素,那么您只需这样做:

newImage = conv2(A.*M2, M1,'same');

这可能足以满足您的目的,但您必须准确确定“平均”的含义。例如,给定您的内核 ones(10),最后您可能想要执行以下操作:

npts = conv2(ones(size(A)).*M2, M1, 'same')
newImage = newImage./npts

即,将每个像素除以实际包含在该像素卷积中的像素数。

实际上,即使您对不同点的权重不同,上述方法也可能会做正确的事情。但这真的取决于你想做什么。

【讨论】:

    【解决方案2】:

    一种快速解决方法是用总平​​均值替换被遮罩像素中的所有值。

    一种更精细的方法是将一个大(非常大)平滑过滤器(就像您已经使用但更大的过滤器)与图像进行卷积,并且只使用结果来填充原始图像中的蒙版像素,现在您对于原始图像中的蒙版像素具有合理的值,您可以像现在一样使用卷积。

    【讨论】:

      猜你喜欢
      • 2011-09-11
      • 1970-01-01
      • 2015-09-17
      • 1970-01-01
      • 2016-12-30
      • 2014-11-18
      • 1970-01-01
      • 1970-01-01
      • 2018-08-23
      相关资源
      最近更新 更多