打开Cv渔业

我有这个问题,

当我运行vs2010(debugging)(打开简历2.4.0)facerec_demo.cpp给我的程序这个错误

OpenCV错误:未知函数,文件…… \ src \ opencv \ modul es \ core> \ src \ matrix中的图像步骤错误(matrix不连续,因此其行数不能更改)。 cpp,801行

这个错误导致我在facerec.cpp中的这一行
(Fisherfaces :: train(InputArray src,InputArray _lbls)

Mat data = asRowMatrix(src, CV_64FC1); <-- this gets a exeption, not handled. 

和ai使用在pgm img数据库,这是我原来的* facerec_demo.cpp *文件

 #include "stdafx.h" #include <opencv2/opencv.hpp> #include <iostream> #include <fstream> #include <vector> #include <string> #include <sstream> using namespace cv; using namespace std; vector<string> split_at_commas(const string& row) { vector<string> res; istringstream buf(row); string s; while (getline(buf, s, ';')) res.push_back(s); return res; } Mat toGrayscale(InputArray _src) { Mat src = _src.getMat(); // only allow one channel if(src.channels() != 1) CV_Error(CV_StsBadArg, "Only Matrices with one channel are supported"); // create and return normalized image Mat dst; cv::normalize(_src, dst, 0, 255, NORM_MINMAX, CV_8UC1); return dst; } void read_csv(const string& filename, vector<Mat>& images, vector<int>& labels, char separator = ';') { //std::ifstream file(filename.c_str(), ifstream::in); std::ifstream file(_T("D:\\Users\\PC ACER\\Documents\\mycsv4.csv")); if (!file) throw std::exception(); string line="", path="", classlabel=""; while (getline(file, line)) { //vector<string> values = split_at_commas(line); stringstream liness(line); getline(liness, path, ';'); getline(liness, classlabel); images.push_back(imread(path, 0)); labels.push_back(atoi(classlabel.c_str())); } } int main(int argc, const char *argv[]) { // check for command line arguments if (argc != 2) { cout << "usage: " << argv[0] << " <csv.ext>" << endl; exit(1); } // path to your CSV string fn_csv = string(argv[1]); // images and corresponding labels vector<Mat> images; vector<int> labels; // read in the data try { read_csv(fn_csv, images, labels); } catch (exception&) { cerr << "Error opening file \"" << fn_csv << "\"." << endl; exit(1); } // get width and height //int width = images[0].cols; int height = images[0].rows; // get test instances Mat testSample = images[images.size() - 1]; int testLabel = labels[labels.size() - 1]; // ... and delete last element images.pop_back(); labels.pop_back(); // build the Fisherfaces model Ptr<FaceRecognizer> model = createFisherFaceRecognizer(); model->train(images, labels); // test model int predicted = model->predict(testSample); cout << "predicted class = " << predicted << endl; cout << "actual class = " << testLabel << endl; // get the eigenvectors Mat W = model->eigenvectors(); // show first 10 fisherfaces for (int i = 0; i < min(10, W.cols); i++) { // get eigenvector #i Mat ev = W.col(i).clone(); // reshape to original size AND normalize between [0...255] Mat grayscale = toGrayscale(ev.reshape(1, height)); // show image (with Jet colormap) Mat cgrayscale; applyColorMap(grayscale, cgrayscale, COLORMAP_JET); imshow(format("%d", i), cgrayscale); } waitKey(0); return 0; } 

Solutions Collecting From Web of "打开Cv渔业"

我看到你正在使用OpenCV 2.4.0。 作为开发人员我承认这个混乱是我的错:当时我没有彻底检查传递给训练方法的输入数据,所以通过错误排列数据的人得到了像你这样的错误信息。 最有可能的是你看到的错误发生,因为你的训练图像没有相同的大小。 这对于Eigenfaces和Fisherfaces算法是必需的(不适用于局部二元模式直方图)。 OpenCV 2.4.0只是试图将数据重塑到一个矩阵,并与您看到的错误消息爆炸; 相反,OpenCV 2.4.2会检查(在训练之前)输入数据是否正确对齐,并抛出一个有意义的异常……并且信息非常清晰。

这篇文章假设它也可能是由于链接OpenCV库:

  • 在Fisherfaces.train()方法中获取OpenCV错误“图像步骤错误”

如果它没有链接库,可能是由于图像大小。 调整您的训练图像,可以很容易地完成OpenCV与cv :: resize :

但是你可能应该考虑切换到OpenCV 2.4.2,在这里添加所有这些:

这个版本还附带了一个广泛的文档:

但是,如果你不能改变OpenCV 2.4.2,你需要留在OpenCV 2.4.0,那么你也可以使用libfacerec:

这是合并到OpenCV中的项目。 我确定它可以和OpenCV 2.4.0一起使用,它会让你的界面和OpenCV 2.4.2版本一样。 所以一旦你想更新到OpenCV 2.4.2,你只能切换包含。

我得到了相同的OpenCV错误,我尝试了所有在这里找到的帮助,它仍然给我一个例外(在.Predict()语句发生异常)。

问题在于图像的大小。 图片的大小必须小于100px(<100px)(不确定是否小于100,大概100也可以)。

我改变我的图片大小150:150到80:80,它的工作!

希望我帮助别人,因为这是令人讨厌的错误。

我在另一个帖子上回答了这个问题,但我想确保搜索帮助这个错误的人一定会找到答案。

当你做模型

 Ptr<FaceRecognizer> model = createFisherFaceRecognizer(); 

你需要通过两个参数

 createFisherFaceRecognizer(int num_components=0, double threshold=DBL_MAX); 

本页面提供了关于createFisherFaceRecognizer如何工作的更多信息