使用高斯3x3滤镜进行锐化但效果是白色像素

时间:2017-03-11 14:34:42

标签: opencv image-processing gaussian convolution

以下程序无效。我正在实现高斯3x3滤镜来锐化图像文件FACE DETECTION.png,但结果只显示白色。我认为在卷积运算中sum的值大于255。我需要一个解决方案......

CODE:

int main()
{

  Mat src, dst;
  float sum;

  /// Load an image
  src = imread("FACE DETECTION.png", 0);

  if( !src.data )
  { return -1; }

  // define the kernel
  float Kernel[3][3] = {
                        {1.0, 2.0, 1.0},
                        {2.0, 4.0, 2.0},
                        {1.0, 2.0, 1.0}
                       };
     dst = src.clone();
    for(int y = 0; y < src.rows; y++)
        for(int x = 0; x < src.cols; x++)
            dst.at<uchar>(y,x) = 0.0;
    //convolution operation
    for(int y = 1; y < src.rows - 1; y++){
        for(int x = 1; x < src.cols - 1; x++){
            sum = 0.0;
            for(int k = -1; k <= 1;k++){
                for(int j = -1; j <=1; j++){
                    sum = sum + Kernel[j+1][k+1]*src.at<uchar>(y - j, x - k);
                    sum = sum>255? 255:sum;
                    sum = sum<0? 0:sum;
                }
            }
            dst.at<uchar>(y,x) = sum;
        }
    }


    namedWindow("final");
    imshow("final", dst);

    namedWindow("initial");
    imshow("initial", src);

  waitKey();


return 0;
}

1 个答案:

答案 0 :(得分:1)

问题在于你的内核。内核的总和应该等于1,但你的等于16。

kernel = 1/16* kernel; 

将解决您的问题。

相关问题