cvCalcOpticalFlowHS()opencv抛出异常

时间:2012-06-06 14:07:00

标签: c++ visual-studio-2010 exception opencv

Heey,我正在尝试解决openCV的光流功能,但由于某些原因我在视觉工作室中遇到异常:

Optical_flow.exe中0x772615de处的未处理异常:Microsoft C ++异常:cv ::内存位置0x0036f334处的异常..

使用断点我发现错误在cvCalcOpticalFlowHS函数中。

我正在使用openCV 2.1

#include <cv.h>
#include <highgui.h>
using namespace cv;

int init() {
  return 0;
}

int main(int argc, char **args) {
  CvCapture* capture = cvCaptureFromFile("Video/Wildlife.wmv");
  double fps = cvGetCaptureProperty(capture, CV_CAP_PROP_FPS);

  CvSize size;
  size.width = (int)cvGetCaptureProperty(capture, CV_CAP_PROP_FRAME_WIDTH);
  size.height = (int)cvGetCaptureProperty(capture, CV_CAP_PROP_FRAME_HEIGHT);

  CvVideoWriter* writer = cvCreateVideoWriter("result.avi", 0, fps,size, 1);

  IplImage* curFrame = cvQueryFrame(capture);

  Mat u = Mat(size, CV_32FC2);
  Mat v = Mat(size, CV_32FC2);

  CvTermCriteria IterCriteria;
  IterCriteria.type = CV_TERMCRIT_ITER | CV_TERMCRIT_EPS;
  IterCriteria.max_iter = 500;
  IterCriteria.epsilon = 0.01;

  while(1) {
    IplImage* nextFrame = cvQueryFrame(capture);

    if(!nextFrame) break;

    u = Mat::zeros(size, CV_32FC2);
    v = Mat::zeros(size, CV_32FC2);

    /* Do optical flow computation */
    cvCalcOpticalFlowHS(&curFrame, &nextFrame, 0, &u, &v, 0.01, IterCriteria);

    cvWriteFrame(writer, curFrame);

    curFrame = nextFrame;
  }

  cvReleaseVideoWriter(&writer);
  cvReleaseCapture(&capture);

  return 0;
}

之前有人见过这个问题或者看到我犯过的错误吗?

最好的问候

REMCO

1 个答案:

答案 0 :(得分:2)

the documentation开始,curFrame和nextFrame应为8位单通道。您目前只是从加载的文件中提取这些内容而不检查/转换它们。你能确认输入的类型是正确的吗?

你也有一个讨厌的C ++风格的cv :: Mat和C风格的IplImage *。我建议您升级到更新版本的OpenCV(2.4最近已经发布),并尝试坚持使用C ++或C风格的一种或另一种方法。

另请注意,此光流方法被归类为过时,建议使用calcOpticalFlowPyrLK()表示稀疏功能,或使用calcOpticalFlowFarneback()表示密集功能。

下面是一些示例代码,演示了calcOpticalFlowFarneback(),这是我相信你想要实现的。它从网络摄像头而不是文件中获取数据。

#include <opencv2/opencv.hpp>

using namespace cv;

void drawOptFlowMap(const cv::Mat& flow,
                    cv::Mat& cflowmap,
                    int step,
                    const cv::Scalar& color
                   )
{
    for(int y = 0; y < cflowmap.rows; y += step)
        for(int x = 0; x < cflowmap.cols; x += step)
        {
            const cv::Point2f& fxy = flow.at<cv::Point2f>(y, x);
            cv::line(cflowmap,
                             cv::Point(x,y),
                             cv::Point(cvRound(x+fxy.x),cvRound(y+fxy.y)),
                 color);
            cv::circle(cflowmap, cv::Point(x,y), 2, color, -1);
        }
}

int main(int argc, char **args) {

    VideoCapture cap(0); // open the default camera
    if(!cap.isOpened())  // check if we succeeded
        return -1;

    Mat newFrame, newGray, prevGray;


    cap >> newFrame; // get a new frame from camera
    cvtColor(newFrame, newGray, CV_BGR2GRAY);
    prevGray = newGray.clone();

    double pyr_scale = 0.5;
    int levels = 3;
    int winsize = 5;
    int iterations = 5;
    int poly_n = 5;
    double poly_sigma = 1.1;
    int flags = 0;

    while(1) {
        cap >> newFrame;
        if(newFrame.empty()) break;
        cvtColor(newFrame, newGray, CV_BGR2GRAY);

        Mat flow = Mat(newGray.size(), CV_32FC2);

        /* Do optical flow computation */
        calcOpticalFlowFarneback(
            prevGray,
            newGray,
            flow,
            pyr_scale,
            levels,
            winsize,
            iterations,
            poly_n,
            poly_sigma,
            flags
            );

        drawOptFlowMap(flow, newFrame, 20, CV_RGB(0,255,0));

        namedWindow("Output",1);
        imshow("Output", newFrame);
        waitKey(1);

        prevGray = newGray.clone();
    }

    return 0;
}

上面的代码非常类似于OpenCV附带的fback.cpp示例代码。