Я использую cvHoughCircles, чтобы найти два белых овала на следующем изображении:
Сначала я использовал пороговое значение для обнаружения белых областей, а затем использовал преобразования Хафа. Но вывод не правильный, как показано ниже:
Я не могу понять, что происходит? Почему он обнаруживает 3 круга и почему только один определяется правильно? Какие-либо предложения?
Ниже мой код:
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp"
#include <iostream>
#include <stdio.h>
#include <math.h>
#include <ctype.h>
#include <stdlib.h>
#include "opencv/cv.h"
#include "opencv/highgui.h"
#include<conio.h>
#include<malloc.h>
using namespace cv;
using namespace std;
int main( ) {
IplImage* image = cvLoadImage(
"testing.bmp",
CV_LOAD_IMAGE_GRAYSCALE
);
IplImage* src = cvLoadImage("testing.bmp");
CvMemStorage* storage = cvCreateMemStorage(0);
cvThreshold( src, src, 200, 255, CV_THRESH_BINARY );
CvSeq* results = cvHoughCircles(
image,
storage,
CV_HOUGH_GRADIENT,
3,
image->width/10
);
for( int i = 0; i < results->total; i++ )
{
float* p = (float*) cvGetSeqElem( results, i );
CvPoint pt = cvPoint( cvRound( p[0] ), cvRound( p[1] ) );
cvCircle(
src,
pt,
cvRound( p[2] ),
CV_RGB(0xff,0,0)
);
}
cvNamedWindow( "HoughCircles", 1 );
cvShowImage( "HoughCircles", src);
cvWaitKey(0);
}
Редактировать:
Поскольку я не получаю удовлетворительных результатов с Hough Transform, я готов пойти другим путем. Я могу предположить, что все белые шарики на рисунке имеют одинаковый размер (размер известен), а также известно расстояние между шариками. Есть ли нетривиальный способ найти вертикальную линию (касательную), касающуюся левой стороны левого белого пятна? Как только я узнаю этот тангенс, я получу представление о местоположении границы, а затем нарисую круг в точке x=(это место + радиус (который известен)), y= это место. Могу ли я найти такие координаты x и y какими-то нетривиальными способами?
Решено, изменив, как показано ниже:
cvThreshold(image, image, 220, 255, CV_THRESH_BINARY );
cvCanny(image, image, 255, 255, 3);
cvNamedWindow( "edge", 1 );
cvShowImage( "edge", image);
cvWaitKey(0);
CvMemStorage* storage = cvCreateMemStorage(0);
CvSeq* results = cvHoughCircles(
image,
storage,
CV_HOUGH_GRADIENT,
4,
image->width/4, 100,100,0,50);
Вот результат: