Opencv, звонок ContuRarea вызывает неудачу сбой в Getmat

StackOverflow https://stackoverflow.com//questions/9700339

  •  13-12-2019
  •  | 
  •  

Вопрос

Я использую OpenCV 2.3.1 на XCode4 OS X 10.7

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

Я хотел бы отфильтровать контуры меньшими, чем определенный размер, но когда я звоню contorarea (), я получаю неудачу следующие утверждения:

OpenCV Error: Assertion failed (0 <= i && i < (int)vv.size()) in getMat, file /opt/local/var/macports/build/_opt_local_var_macports_sources_rsync.macports.org_release_ports_graphics_opencv/opencv/work/OpenCV-2.3.1/modules/core/src/matrix.cpp, line 912
terminate called throwing an exception
.

Соответствующий код:

for( ; idx >= 0; idx = hierarchy[idx][0] ) {
           //double area = contourArea(contours);
           //cout << area << endl;
           Scalar color( rand()&255, rand() &255, rand()&255);
           drawContours(dst, contours, idx, color);
       }
.

, который является последним для цикла:

#include "opencv/cv.h"
#include "opencv/highgui.h"
#include <iostream>
#include <vector>
#include "opencv2/video/background_segm.hpp"


using namespace std;
using namespace cv;

void refineSegments(const Mat& img, Mat& mask, Mat& dst)
{
int niters = 3;

vector<vector<Point> > contours;
vector<Vec4i> hierarchy;

Mat temp;

dilate(mask, temp, Mat(), Point(-1,-1), niters);
erode(temp, temp, Mat(), Point(-1,-1), niters*2);
dilate(temp, temp, Mat(), Point(-1,-1), niters);

findContours( temp, contours, hierarchy, CV_RETR_CCOMP, CV_CHAIN_APPROX_SIMPLE );

dst = Mat::zeros(img.size(), CV_8UC3);

if( contours.size() == 0 )
    return;

// iterate through all the top-level contours,
// draw each connected component with its own random color
int idx = 0;

for( ; idx >= 0; idx = hierarchy[idx][0] ) {
    double area = contourArea(contours);
    cout << area << endl;
    Scalar color( rand()&255, rand() &255, rand()&255);
    drawContours(dst, contours, idx, color);
}
}
.

Я жалуюсь кусочкам кода в источнике:

if( k == STD_VECTOR_VECTOR )
{
    int t = type(i);
    const vector<vector<uchar> >& vv = *(const vector<vector<uchar> >*)obj;
    CV_Assert( 0 <= i && i < (int)vv.size() );
    const vector<uchar>& v = vv[i];

    return !v.empty() ? Mat(size(i), t, (void*)&v[0]) : Mat();
}
.

Но я не могу сделать голову или хвосты этого ... Я int, который передается getmat, но то, что это на самом деле, и почему он должен быть меньше 0, выходит за пределы меня> __ <. Мне кажется очень странным для меня, что эта стандартная функция делает это, может ли кто-нибудь пролить немного света на это?

Это было полезно?

Решение

Это простое опечатка.Вы даете все контуры в функцию CONTORAREA:

double area = contourArea(contours);
.

Вы, вероятно, хотели

double area = contourArea(contours[idx]);
.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top