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

码:

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,而您的等于16。

kernel = 1/16* kernel;

将解决您的问题。

关于opencv - 使用高斯3x3滤镜锐化有效,但结果是白色像素,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42736437/

10-12 06:17