Нахождение точек в контурах

Итак, вот код, который я использовал для обнаруженияконтуры:

IplImage* DetectAndDrawQuads(IplImage* img)

{
CvSeq* contours;
CvSeq* result;
CvMemStorage *storage = cvCreateMemStorage(0);

IplImage* ret = cvCreateImage(cvGetSize(img), 8, 3);
IplImage* temp = cvCreateImage(cvGetSize(img), 8, 1);

cvCvtColor(img, temp, CV_BGR2GRAY);

cvFindContours(temp, storage, &contours, sizeof(CvContour), CV_RETR_LIST, CV_CHAIN_APPROX_SIMPLE, cvPoint(0,0));

while(contours)
{
    result = cvApproxPoly(contours, sizeof(CvContour), storage, CV_POLY_APPROX_DP, cvContourPerimeter(contours)*0.10, 0); //*0.2


    if((result->total) == 4)  
    {
        CvPoint *pt[4];
        for(int i=0;i<4;i++)
            pt[i] = (CvPoint*)cvGetSeqElem(result, i);

            cvLine(ret, *pt[0], *pt[1], cvScalar(255));
            cvLine(ret, *pt[1], *pt[2], cvScalar(255));
            cvLine(ret, *pt[2], *pt[3], cvScalar(255));
            cvLine(ret, *pt[3], *pt[0], cvScalar(255));


    }

    contours = contours->h_next;

}

cvReleaseImage(&temp);
cvReleaseMemStorage(&storage);

return ret;
}


int main()

{

    IplImage* img = cvLoadImage("D:\\Database\\eye2.jpg");
IplImage* contourDrawn = 0;
cvNamedWindow("original");
cvShowImage("original", img);

contourDrawn = DetectAndDrawQuads(img);
cvNamedWindow("contours");
cvShowImage("contours", contourDrawn);

cvWaitKey(0);
return 0;
}

И этофильм что я использовал для тестирования программы:вход

Я пытаюсь получить контуры в качестве предварительного шага в поиске выражения лица введенного лица. И этоРезультат когда я пытался запустить программу (оригинал [слева] иВыход [правильно]):Результат

Как вы можете видеть, кажется, что в двоичном изображении остался некоторый шум (который я на самом деле предварительно обработал до того, как он был введен в мою программу поиска контуров (коды выше)).

Мой вопрос:



Как найти точки в контурах (например, верхняя, нижняя, центральная, крайняя левая и крайняя правая точки -> необходимые точки для выполнения геометрических расчетов для определения выражения лица).

Большое спасибо, если вы мне поможете. Пока что это лучший вывод, который я мог сгенерировать в отношении поиска контуров. Также, если вы можете помочь мне более точно извлечь контуры, это будет очень цениться. Спасибо. :)

Ответы на вопрос(1)

Ваш ответ на вопрос