问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

OpenCV进行图形匹配的方法,如若原图图中没有欲找的图,怎么设置返回错误.....

发布网友 发布时间:2022-04-23 08:43

我来回答

2个回答

热心网友 时间:2023-10-08 22:17

OpenCV封装了很多各种各样的匹配函数,如果想简单一点解决你的问题,你可以试试用chamerMatching函数。这个是C++程序,OpenCV2.0.0之后的版本应该都有(没有查,手头上只有2.4.4和2.4.6,都是有的)。顺便附上简单的代码,你可以试试。

#include "opencv2/imgproc/imgproc.hpp"
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/contrib/contrib.hpp"

#include <iostream>

using namespace cv;
using namespace std;

void help()
{
 
   cout << "\nThis program demonstrates Chamfer matching -- computing a distance between an \n"
            "edge template and a query edge image.\n"
            "Usage: \n"
            "./chamfer <image edge map> <template edge map>,"
            " By default the inputs are logo_in_clutter.png logo.png\n";
}

const char* keys = 
{
    "{1| |logo_in_clutter.png|image edge map    }"
    "{2| |logo.png               |template edge map}"
};

int main( int argc, const char** argv )
{

    help();
    CommandLineParser parser(argc, argv, keys);

    string image = parser.get<string>("1");
    string templ = parser.get<string>("2");
    Mat img = imread(image.c_str(), 0);
    Mat tpl = imread(templ.c_str(), 0);

    if (img.empty() || tpl.empty())
    {
        cout << "Could not read image file " << image << " or " << templ << "." << endl;
        return -1;
    }
    Mat cimg;
    cvtColor(img, cimg, CV_GRAY2BGR);

    // if the image and the template are not edge maps but normal grayscale images,
    // you might want to uncomment the lines below to proce the maps. You can also
    // run Sobel instead of Canny.

    // Canny(img, img, 5, 50, 3);
    // Canny(tpl, tpl, 5, 50, 3);

    vector<vector<Point> > results;
    vector<float> costs;
    int best = chamerMatching( img, tpl, results, costs );
    if( best < 0 )
    {
        cout << "matching not found" << endl;
        return -1;
    }

    size_t i, n = results[best].size();
    for( i = 0; i < n; i++ )
    {
        Point pt = results[best][i];
        if( pt.inside(Rect(0, 0, cimg.cols, cimg.rows)) )
           cimg.at<Vec3b>(pt) = Vec3b(0, 255, 0);
    }

    imshow("result", cimg);

    waitKey();

    return 0;
}

 忘了说了,chamerMatching的输出值如果小于0,表示没有发现匹配项。

追问亲,能相信说明一下chamerMatching用法么?在百度上查找这个函数没有找到啊,有点郁闷。

追答OpenCV手册中是这么介绍的:

This program demonstrates Chamfer matching -- computing a distance between an edge template and a query edge image.
contrib.hpp中的函数原型声明是这样的:
int chamerMatching( Mat& img, Mat& templ,
vector >& results, vector& cost,
double templScale=1, int maxMatches = 20,
double minMatchDistance = 1.0, int padX = 3,
int padY = 3, int scales = 5, double minScale = 0.6, double maxScale = 1.6,
double orientationWeight = 0.5, double truncate = 20);
简单解释一下:
chamerMatching()是用来进行轮廓匹配的。源图像和目标图像都需要先提取出轮廓,例如canny算子。例如:源图像templ,目标图像img,best=chamerMatching(img,templ,results,cost)。results[]存放匹配结果。每个results[i]都是一系列点集构成的链表,例如result[1]={(120,120),(121,120),...},这些点集组成一幅轮廓图像。而best表示匹配效果最好的index,所以可以认为result[best]就是想要的结果。如果best小于0表示没有发现匹配项。
函数里面其他的默认参数一般可以不用改动。

热心网友 时间:2023-10-08 22:18

程序会给出每次识别的类似相似度的值,可以通过和正确图的值比较判断是否为正确图
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
养胃的药最好的是什么啊 婴儿积食发烧不愿吃药怎么办 板门穴位在哪个部位 手机设置放偷看的方法? 凝结水回收器生产厂家? 个人账户养老金预测公式:现有5万元,缴费20年,能领多少钱? 临沂比较有名的男装品牌 呼伦贝尔市悦动网络科技有限公司怎么样? 呼伦贝尔中汇实业有限公司怎么样? 呼伦贝尔油玉不绝电子商务有限公司怎么样? opencv模板匹配 如何加载模板已改填在哪里 template matching;templet matching是什么意思 opencv的模板匹配如何计算置信度? opencv 中自带的模板匹配算法,不能显示结果。 苹果手机电池掉的很快怎么办 今天手机无缘无故发热,掉电很快,怎么回事? 手机电池掉电快是什么原因呢? 手机电池掉电可快了 是什么原因 手机掉电很快是电池的原因还是手机本身? 华为手机掉电越来越快是怎么回事呢? 一般证券业务跟证券投资咨询业务有什么区别 金融学专业找什么样的工作?除了银行和证券外的 证券投资咨询业务、证券投资顾问业务,这两个区别在哪? 圆石金融技术服务(上海)有限公司怎么样? 上海久曦投资咨询有限公司怎么样? 证券投资咨询机构的业务都有哪些? 请问工商执照上经营范围:非金融性项目投资咨询(国家禁止*的除外) 是什么意思? 上海致外投资咨询有限公司怎么样? 上海鼎爵投资咨询有限公司怎么样? 投资咨询公司主要是做什么? opencv如何回撤到原图 opencv Matchtemplate遍历原理以及有哪些优化 opencv图片对比 opencv cvMatchTemplate问题 如何在Qt中使用OpenCV C++怎么调用openMVG库 linux下qt配置的opencv出现libopencv_calib3d.so: file not recognized: File format not recognized opencv访问矩阵元素出错!! opencv中ptr的用法 家里的旧房子是顶楼总是漏水,该如何处理呢? python 3.5.1 怎么添加opencv2.4.9 老房子屋顶漏水怎么处理? matchtemplate 这个函数在opencv gpu中可以使用吗 老房子,没有物业,楼上漏水,找谁负责? vr眼镜选那种比较好,淘宝上几十块钱的可以吗? 如何序列化 opencv mat类对象 老房子屋顶漏水怎么办? 请问vr眼镜价格一般是多少啊? 老房子没有物业 房顶漏水找谁负责? 顶楼漏水如何处理