0

opencv 2.4.7 で cvcalcopticalflowBM 関数を使用してオプティカル フローを計算したい。エラー メッセージは、「入力引数のサイズが cvcalcopticalflowbm で macth() を実行できません。

なぜなのかわかりません。私を助けてください。よろしくお願いします。

#define BS 5

IplImage *imgA = NULL, *imgB = NULL;
IplImage *grayA = NULL, *grayB = NULL;
IplImage *velx = NULL, *vely = NULL;
IplImage *result = NULL;
imgA = cvLoadImage("00.jpg", 1);
imgB = cvLoadImage("01.jpg", 1);
grayA = cvCreateImage(cvGetSize(imgA), IPL_DEPTH_8U, 1);
grayB = cvCreateImage(cvGetSize(imgA), IPL_DEPTH_8U, 1);

cvCvtColor(imgA, grayA, CV_BGR2GRAY);
cvCvtColor(imgB, grayB, CV_BGR2GRAY);

CvSize size = cvGetSize(imgA);
size.width /= BS;
size.height /= BS;
result = cvCreateImage(size, IPL_DEPTH_8U, 1);
for (int i=0; i<size.height; i++) {
    for (int j=0; j<size.width; j++) {
        cvSet(result, CV_RGB(255,255,255), NULL);
    }
}
velx = cvCreateImage(size, IPL_DEPTH_32F, 1);
vely = cvCreateImage(size, IPL_DEPTH_32F, 1);
cvCalcOpticalFlowBM(grayB, grayA, cvSize(BS, BS), cvSize(1, 1), cvSize(1, 1), 0, velx, vely);
//
cvNamedWindow("HorFlowBM", CV_WINDOW_AUTOSIZE);
cvShowImage("HorFlowBM", velx);
cvNamedWindow("VerFlowBM", CV_WINDOW_AUTOSIZE);
cvShowImage("VerFlowBM", vely);
for (int i=0; i<size.height; i+=2) {
    for (int j=0; j<size.width; j+=2) {
        int dx = (int)cvGetReal2D(velx, i, j);
        int dy = (int)cvGetReal2D(vely, i, j);
        cvLine(result, cvPoint(j, i), cvPoint(j+dx, i+dy), CV_RGB(0,0,0), 1, 8, 0);
    }
}
cvNamedWindow("OpticalFlow", CV_WINDOW_AUTOSIZE);
cvShowImage("OpticalFlow", result);
cvWaitKey(0);
4

2 に答える 2

0

このエラーを認識しました。velx と vely のサイズは

CvSize velSize =
{
    (grayA->width - BLOCK_SIZE + SHIFT_SIZE)/SHIFT_SIZE,
    (grayA->height - BLOCK_SIZE + SHIFT_SIZE)/SHIFT_SIZE
};

プログラムをコンパイルすると正しくなる

于 2014-02-15T15:18:24.637 に答える
0

入力画像が読み込まれていることを確認してください。それらをロードした後、それらを表示してみてくださいcvShowImage("input1", imgA);。また、両方の画像のサイズを印刷して、両方の画像のサイズが同じであることを確認してください。

于 2014-02-15T08:10:53.270 に答える