OpenCVを用いてテンプレートマッチングを試したところエラーが出てしまいました。
画像を取り込んだ後cvMatchTemplate関数、cvMinMaxLoc関数によって閾値以上マッチングのあった場所を四角で囲むというプログラムです。
調べたところcvMatchTemplateのところでエラーが出ているのですがこのエラーに関して全然情報が出てこず困っております。
これに関してご存知のかたがいらっしゃればご教授ください。
よろしくお願いします。
エラー:Unknown error code -25(Bad imnput roi) in cvInitImageHeader
コード全体は以下です。
c
1#include <opencv2/opencv.hpp> 2using namespace cv; 3 4#define THRESHOLD 0.7 5 6 7int main(int argc, char *argv[]) 8{ 9 10 IplImage *im = cvLoadImage("sample1.JPG"); //画像のよみこみ 11 if (im == NULL){ 12 printf("画像が見つかりません(元画像)"); 13 return 0; 14 } 15 16 IplImage *result; //結果表示用画像の用意 17 result = cvCloneImage(im); 18 19 IplImage *pai; 20 21 //ファイルの読み込み 22 char filename[31]; 23 sprintf(filename, "sample\\%d.jpg", 2); 24 pai = cvLoadImage(filename); 25 if (pai == NULL){ 26 printf("画像が見つかりません(辞書)"); 27 exit(1); 28 } 29 30 CvSize result_size = cvSize(im->width - pai->width + 1, im->height - pai->height + 1); 31 IplImage *result_img; 32 result_img= cvCreateImage(result_size, IPL_DEPTH_32F, 1); 33 34 35 cvMatchTemplate(im, pai, result_img, CV_TM_CCOEFF_NORMED); 36 double max_val; 37 CvPoint max_pos; 38 cvMinMaxLoc(result_img, NULL, &max_val, NULL, &max_pos, NULL); 39 40 if (max_val > THRESHOLD){ //テンプレート一致が見つかった時塗りつぶす 41 cvRectangle(result, max_pos, cvPoint(max_pos.x + pai->width, max_pos.y + pai->height), CV_RGB(0, 255, 0), 2); 42 } 43 44 45 cvShowImage("result2",result); 46 47 waitKey(); 48 cvReleaseImage (&im); 49 cvReleaseImage (&result); 50 cvReleaseImage (&pai); 51 cvReleaseImage (&result_img); 52 return 0; 53}
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。