0

我正在尝试编写简单的程序来识别一些简单的模式。它适用于 tesseract,但由于某种原因它不适用于Hmm. 这是示例代码:

std::string image_path = "assets/ubuntu.png";
std::string filename = "assets/OCRHMM_transitions_table.xml";
auto image_source = cv::imread(image_path);
cv::Mat image;
cv::cvtColor(image_source, image, 6);
cv::Mat transition_p;
cv::FileStorage fs(filename, cv::FileStorage::READ);
fs["transition_probabilities"] >> transition_p;
fs.release();
cv::Mat emission_p = cv::Mat::eye(62,62,CV_64FC1);
std::string voc = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
auto classifier = cv::text::loadOCRHMMClassifierNM("assets/OCRHMM_knn_model_data.xml.gz");
auto ocr = cv::text::OCRHMMDecoder::create(classifier, voc, transition_p, emission_p);

std::string output;
std::vector<cv::Rect> boxes;
std::vector<std::string> words;
std::vector<float> confidences;
ocr.get()->run(image, output, &boxes, &words, &confidences);
std::cout << output;

和示例图像:

在此处输入图像描述

预期输出:uBuntu

实际输出:m

这段代码有什么问题?我只是尝试采用演示样本

这是使用的OCRHMM_transitions_table.xmlOCRHMM_knn_model_data.xml.gz(我实际上也从这个示例中获取了它们)。

OpenCV 版本 3.4.0

4

1 回答 1

0

级联分类器看起来训练不足。你为什么不使用另一个分类器?它检测到你一半的 m

在此处输入图像描述

于 2018-02-13T16:49:51.140 回答