gpt4 book ai didi

iphone - 使用 HoughCircles 检测和测量瞳孔和虹膜

转载 作者:可可西里 更新时间:2023-11-01 04:47:14 24 4
gpt4 key购买 nike

我正在尝试使用 OpenCV,更具体地说是它的 HoughCircles 来检测和测量瞳孔和虹膜,目前我一直在使用函数中的一些变量,因为它要么返回 0 个圆圈,要么返回过多的圆圈.下面是我正在使用的代码和测试图像。

虹膜测量代码:

 eye1 = [self increaseIn:eye1 Contrast:2 andBrightness:0];

cv::cvtColor(eye1, eye1, CV_RGBA2RGB);
cv::bilateralFilter(eye1, eye2, 75, 100, 100);

cv::vector<cv::Vec3f> circles;

cv::cvtColor(eye2, eye1, CV_RGBA2GRAY);

cv::morphologyEx(eye1, eye1, 4, cv::getStructuringElement(cv::MORPH_RECT,cv::Size(3, 3)));
cv::threshold(eye1, eye1, 0, 255, cv::THRESH_OTSU);

eye1 = [self circleCutOut:eye1 Size:50];

cv::GaussianBlur(eye1, eye1, cv::Size(7, 7), 0);

cv::HoughCircles(eye1, circles, CV_HOUGH_GRADIENT, 2, eye1.rows/4);

测量瞳孔的代码:

eye1 = [self increaseBlackPupil:eye1];
cv::Mat eye2 = cv::Mat::zeros(eye1.rows, eye1.cols, CV_8UC3);

eye1 = [self increaseIn:eye1 Contrast:2 andBrightness:0];

cv::cvtColor(eye1, eye1, CV_RGBA2RGB);
cv::bilateralFilter(eye1, eye2, 75, 100, 100);

cv::threshold(eye2, eye1, 25, 255, CV_THRESH_BINARY);

cv::SimpleBlobDetector::Params params;
params.minDistBetweenBlobs = 75.0f;
params.filterByInertia = false;
params.filterByConvexity = false;
params.filterByCircularity = false;
params.filterByArea = true;
params.minArea = 50;
params.maxArea = 500;

cv::Ptr<cv::FeatureDetector> blob_detector = new cv::SimpleBlobDetector(params);
blob_detector->create("SimpleBlob");
cv::vector<cv::KeyPoint> keypoints;
blob_detector->detect(eye1, keypoints);

enter image description here

我知道图像很粗糙,我也一直在尝试找到一种方法来清理它并使边缘更清晰。

所以我的问题说白了:我可以做些什么来调整函数 HoughCircles 中的参数或更改图像以检测到虹膜和瞳孔?

谢谢

最佳答案

好吧,没有太多实验,我的理解是你在使用霍夫圆检测器之前只对图像应用了双边滤波器。

在我看来,您需要在流程中加入一个阈值步骤。

我获取了您在帖子中提供的示例图片,并对其进行了以下步骤:

  1. 转换为灰度

  2. 形态梯度

  3. 阈值处理

  4. 霍夫圆检测。

在阈值化步骤之后,我只得到了左眼的下图:

thresholded image

代码如下:

灰度:

   cvCvtColor(im_rgb,im_rgb,CV_RGB2GRAY);

形态:

      cv::morphologyEx(im_rgb,im_rgb,4,cv::getStructuringElement(cv::MORPH_RECT,cv::Size(size,size)));

阈值:

    cv::threshold(im_rgb, im_rgb, low, high, cv::THRESH_OTSU);

霍夫圆检测:

    cv::vector<cv::Vec3f> circles;
cv::HoughCircles(im_rgb, circles, CV_HOUGH_GRADIENT, 2, im_rgb.rows/4);

现在当我打印时:

    NSLog(@"Found %ld cirlces", circles.size());

我得到:

     "Found 1 cirlces"

希望这对您有所帮助。

关于iphone - 使用 HoughCircles 检测和测量瞳孔和虹膜,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17890838/

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