сглаживание по Гауссу с использованием opencv

Я создал следующее гауссовское ядро ​​в OpenCV и сравнил его с функцией GaussianBlur в OpenCV. Тем не менее, я получаю черное изображение вместо гладкого изображения. Может кто-нибудь пролить свет на это?

Mat src, dst1,dst2;
Mat gaussiankrnl(3,3,CV_32F);
Point anchor;
double delta;
int ddepth;

anchor = Point( -1, -1 );
delta = 0;
ddepth = -1;

src = imread("coins.pgm");gaussiankrnl.at<double>(0,0) = 1/16;
gaussiankrnl.at<double>(0,1) = 2/16;
gaussiankrnl.at<double>(0,2) = 1/16;
gaussiankrnl.at<double>(1,0) = 2/16;
gaussiankrnl.at<double>(1,1) = 4/16;
gaussiankrnl.at<double>(1,2) = 2/16;
gaussiankrnl.at<double>(2,0) = 1/16;
gaussiankrnl.at<double>(2,1) = 2/16;
gaussiankrnl.at<double>(2,2) = 1/16;filter2D(src, dst1, ddepth , gaussiankrnl, anchor, delta, BORDER_DEFAULT );

GaussianBlur(src, dst2, Size(3,3), 1.0);

imshow("result1", dst1 );
imshow("result2", dst2 );

cvWaitKey(0);
return 0;

0

Решение

Вы делите целые числа и делаете нулевое ядро.

+ Изменить 1/16 в 1.0/16.0 а также другие ценности.

5

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]