/ / Gaussian 3x3フィルタを使用して鮮明化しますが、結果は白のピクセルです - opencv、画像処理、ガウス、コンボリューション

Gaussian 3x3フィルタを使用して鮮明化しますが、その結果は白のピクセルです - opencv、画像処理、ガウス、畳み込み

次のプログラムは動作しません。私は画像ファイルをシャープにするためにガウス3x3フィルタを実装しています FACE DETECTION.pngしかし、結果はちょうど白色を示しています。畳み込み演算でsumの値が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は1

問題はあなたのカーネルです。カーネルの合計は1に等しくなければなりませんが、あなたの数は16に等しくなります。

kernel = 1/16* kernel;

あなたの問題を解決します。