gpt4 book ai didi

opencv - 在虹膜的opencv中使用霍夫圆函数查找分钟圆

转载 作者:行者123 更新时间:2023-12-02 17:53:04 27 4
gpt4 key购买 nike

我需要使用在opencv2中可用的HoughCircle函数来检测眼图的虹膜。所以,

// Read the image
src = imread("D:/001R_3.png");
if( !src.data )
{ return -1; }

/// Convert it to gray
cvtColor( src, src_gray, CV_BGR2GRAY );

/// Reduce the noise so we avoid false circle detection
GaussianBlur( src_gray, src_gray, Size(9, 9), 2, 2 );

/////////////
/// Generate grad_x and grad_y
Mat grad_x, grad_y;
Mat abs_grad_x, abs_grad_y;

Sobel( src_gray, grad_x, ddepth, 1, 0, 3, scale, delta, BORDER_DEFAULT );
convertScaleAbs( grad_x, abs_grad_x );

/// Gradient Y
//Scharr( src_gray, grad_y, ddepth, 0, 1, scale, delta, BORDER_DEFAULT );
Sobel( src_gray, grad_y, ddepth, 0, 1, 3, scale, delta, BORDER_DEFAULT );
convertScaleAbs( grad_y, abs_grad_y );

/// Total Gradient (approximate)
addWeighted( abs_grad_x, 0.5, abs_grad_y, 0.5, 0, grad );
///////////////
vector<Vec3f> circles;

/// Apply the Hough Transform to find the circles
HoughCircles( grad, circles, CV_HOUGH_GRADIENT, 1, grad.rows/8, 200, 100,0,0 );

/// Draw the circles detected
for( size_t i = 0; i < circles.size(); i++ )
{
Point center(cvRound(circles[i][0]), cvRound(circles[i][1]));
cout<<center;
int radius = cvRound(circles[i][2]);
// circle center
cout<<radius;
circle(src, center, 3, Scalar(0,255,0), -1, 8, 0 );
// circle outline
circle(src, center, radius, Scalar(0,0,255), 3, 8, 0 );
}

/// Show your results
namedWindow( "Hough Circle Transform Demo", CV_WINDOW_AUTOSIZE );
imshow( "Hough Circle Transform Demo",src );
}

所以这是我的代码,仅检测到眼睛的外部,因为我希望检测到瞳孔和虹膜边界,而这没有发生,我引用了链接 OpenCV: Using Hough Circle Transformation to detect iris
但是那样行不通。代替精明的边缘检测器已使用sobel。请提出建议。

最佳答案

霍夫变换的第五个参数是minDist或圆之间的最小距离(以像素为单位)。您已将此参数设置为图像中的行数除以8,这意味着将不会返回任何重叠的圆(例如您的眼睛的瞳孔和虹膜),因为它们太靠近了。

我将这个数字设置为变量,而不是对其进行硬编码,然后尝试使用一组更小的数字,直到找到可行的方法。

关于opencv - 在虹膜的opencv中使用霍夫圆函数查找分钟圆,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15279892/

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