gpt4 book ai didi

c++ - 带 mask 的 OpenCV 和 cvAvgSdv (roi)

转载 作者:太空宇宙 更新时间:2023-11-03 22:58:35 27 4
gpt4 key购买 nike

我正在尝试对感兴趣的圆形区域中图像的像素值进行平均。我正在尝试使用 cvAvgSdv,它返回一个合理的均值,但标准差为零。我也尝试 cvCountNonZero 也返回零。一定是我犯的一个基本错误,但希望有人能指出来。 roi.png 看起来正确(黑色背景上正确位置的白点)。我的完整代码如下(VS C++ 2010 Express,Opencv245):

#include <opencv/cv.h>
#include <opencv2/highgui/highgui.hpp>
#include <stdio.h>

int main( int argc, char** argv )
{
IplImage* src;
if( argc >= 2 && (src=cvLoadImage(argv[1], 0))!= 0)
{
IplImage * roi;
roi = cvCreateImage(cvGetSize(src), 8, 1);

int n;
int centre_x = 396, centre_y = 317;
CvScalar pixel_mean, pixel_stdev;

cvZero(roi);
cvCircle(
roi,
cvPoint(centre_x, centre_y),
15, //radius<<<<<<<<<<<<<<<<<<<<<<<<<<<
cvScalar(255),
-1, 8, 0
);
cvAvgSdv(src, &pixel_mean, &pixel_stdev, roi);
n = cvCountNonZero(roi);

printf
(
"center x: %d y: %d A: %d B: %d av: %f stdev: %f n: %d\n",
centre_x,
centre_y,
15,
15,
pixel_mean, //new
pixel_stdev, //new
n //new
);

cvSaveImage("roi.png", roi, 0);
}
}

谢谢

最佳答案

printf 错误和 cvScalars 的使用。使用 pixel_mean.val[0]pixel_stdev.val[0] 代替 pixel_meanpixel_stdev。该部分代码变为:

printf
(
"center x: %d y: %d A: %d B: %d av: %f stdev: %f n: %d\n",
centre_x,
centre_y,
15,
15,
pixel_mean.val[0], //new
pixel_stdev.val[0], //new
n //new
);

一个更安全的方法是独立打印每个变量,那么如果你忘记了 .val[0] 部分也没关系:

printf
(
"center x: %d y: %d A: %d B: %d",
centre_x,
centre_y,
15,
15
);
printf(" av: %f", pixel_mean.val[0]); //new
printf(" stdev: %f", pixel_stdev.val[0]); //new
printf(" n: %d\n", n); //new

看起来有点麻烦,不过忘记.val[0]也没关系,安全多了。

关于c++ - 带 mask 的 OpenCV 和 cvAvgSdv (roi),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23498560/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com