当前位置: 首页 > news >正文

C# OpenCV机器视觉:利用CNN实现快速模板匹配

在一个阳光灿烂的周末,阿强正瘫在沙发上,百无聊赖地换着电视频道。突然,一则新闻吸引了他的注意:某博物馆里一幅珍贵的古画离奇失踪,警方怀疑是被一伙狡猾的盗贼偷走了,现场只留下一些模糊不清的监控画面,根本无法确定盗贼的行踪。阿强看着电视里那一团乱麻的线索,眼睛突然一亮,心中涌起一股热血:“要是我能帮警方找到盗贼,那可就太酷了!说不定还能得到博物馆的巨额悬赏,从此走上人生巅峰呢!”

说干就干,阿强立马冲进他那堆满各种电子设备和书籍的 “秘密基地”。他一边翻箱倒柜,一边嘴里嘟囔着:“我就不信了,凭我这一身的科技本领,还找不到几个毛贼!” 就在这时,他的目光落在了一台布满灰尘的电脑上,脑海中突然闪过一个念头:“对了!我可以用 OpenCvSharp 结合 CNN 来进行模板匹配,从监控画面里找出盗贼的蛛丝马迹!”

第一章:神秘的 CNN—— 图像世界的 “超级侦探”
阿强深知,要想在这复杂的图像世界里找到盗贼的线索,CNN(卷积神经网络)可是他的秘密武器。但这个 CNN 到底是何方神圣呢?阿强决定给它编一个神秘的故事,好让自己更有干劲。

“传说中,CNN 是图像世界里的一位超级侦探,它有着一双无比锐利的眼睛,能看穿图像里隐藏的所有秘密。” 阿强一边对着空气比划,一边眉飞色舞地说道,“它的大脑里装满了各种神奇的算法,就像一个藏满了魔法道具的宝库。当它面对一张图像时,就会施展它的魔法,把图像里的各种特征都提取出来,然后和它记忆中的模板进行比对,不管是多么微小的细节,都逃不过它的法眼。”

阿强越说越兴奋,仿佛自己已经成为了 CNN 的主人,带着它在图像世界里大杀四方:“比如说,我们要找一个特定的图案,CNN 就会像一个不知疲倦的寻宝者,在图像的每一个角落仔细搜寻。它会用它的魔法卷积核,一层一层地扫描图像,就像在给图像做一次深度按摩,把那些隐藏在像素背后的秘密都挖掘出来。一旦发现和模板相似的地方,它就会像发现了宝藏一样,立刻发出信号。”

第二章:筹备 “抓贼” 行动 —— 装备与知识武装
阿强决定先从监控画面里提取一些可能和盗贼有关的模板,比如他们的身形、衣着特征等。他打开电脑,启动 OpenCvSharp,开始加载监控图像和制作模板。

“嘿,老伙计,今天就靠你帮我找出那些可恶的盗贼了!” 阿强拍了拍电脑,像是在给它打气。

他小心翼翼地从监控视频中截取了几帧画面,然后用图像处理软件把盗贼的大致轮廓勾勒出来,制作成模板。“这些模板就是我们的‘通缉令’,只要盗贼在图像里出现,就别想逃过我们的追捕!” 阿强看着屏幕上的模板,信心满满地说道。

接下来,就是要把这些模板和 OpenCvSharp 里的 CNN 算法结合起来,让它们发挥出最大的威力。阿强开始编写代码,虽然他心里也有点紧张,但一想到自己即将成为英雄,就充满了动力。

阿强一边编写代码,一边在心里默默念叨:“我先把图像和模板都加载进来,就像把案件的线索和嫌疑人的画像都收集好。然后把模板标准化,让它们都有相同的尺寸,这样 CNN 才能更好地比对。接着把模板合并成一个多通道的卷积核,这就像是给 CNN 一把超级武器,让它能同时搜索多个目标。再用这个卷积核对图像进行卷积操作,就像让 CNN 在图像里进行地毯式搜索。最后,设置一个相似度阈值,只要找到的匹配度超过这个阈值,就说明我们可能找到了盗贼的踪迹!”

class CNN模板匹配
{static void TEST(){// 加载图像和多个模板  Mat image = Cv2.ImRead(@"D:\软件\core\test\Image_20240622141940849.bmp", ImreadModes.Grayscale);Mat template1 = Cv2.ImRead(@"D:\软件\core\template\1274.png", ImreadModes.Grayscale);Mat template2 = Cv2.ImRead(@"D:\软件\core\template\1282.png", ImreadModes.Grayscale);// 标准化模板  Size templateSize = new Size(33, 33);Cv2.Resize(template1, template1, templateSize);Cv2.Resize(template2, template2, templateSize);// 合并模板为一个多通道卷积核  Mat filters = new Mat();Cv2.Merge(new Mat[] { template1, template2 }, filters); // 合并模板为多通道  // 创建输出图像  Mat outputImg = new Mat(image.Size(), MatType.CV_8UC3);Cv2.CvtColor(image, outputImg, ColorConversionCodes.BGR2RGB); // 转换为 RGB 格式以便于显示 // 执行卷积操作  Mat result = new Mat();Cv2.Filter2D(image, result, MatType.CV_32F, filters); // 使用多通道卷积核进行卷积  // 设置相似度阈值  double similarityThreshold = 0.8;// 计算每个模板的参考值  double[] referenceValues = new double[filters.Channels()];for (int i = 0; i < filters.Channels(); i++){referenceValues[i] = Cv2.Sum(filters.Split()[i])[0]; // 计算每个模板的参考值  }// 可视化所有匹配位置  for (int y = 0; y < result.Rows; y++){for (int x = 0; x < result.Cols; x++){// 获取匹配值  double outputValue = result.At<float>(y, x);// 计算相似度  for (int i = 0; i < referenceValues.Length; i++){double similarity = 1 - Math.Abs(outputValue - referenceValues[i]) / referenceValues[i];// 仅在相似度超过阈值时可视化匹配位置  if (similarity > similarityThreshold){int centerX = x; // 圆心的 x 坐标  int centerY = y; // 圆心的 y 坐标  Cv2.Circle(outputImg, new Point(centerX, centerY), 2, new Scalar(179, 240, 240), thickness: 1);Cv2.Rectangle(outputImg, new Rect(x, y, templateSize.Width, templateSize.Height), new Scalar(179, 240, 240), 1);}}}}// 显示结果  Cv2.ImShow("Match Result", outputImg);Cv2.WaitKey(0);Cv2.DestroyAllWindows();}
}

第三章:代码冲锋 —— 让 CNN “大显身手”
代码编写完成后,阿强深吸一口气,按下了运行键。电脑屏幕上的图像开始快速闪烁,CNN 就像一个不知疲倦的侦探,在图像的每一个角落仔细搜寻着。

“快了,快了,马上就能找到那些盗贼了!” 阿强紧张地盯着屏幕,眼睛都不敢眨一下。

突然,屏幕上出现了几个绿色的圆圈和矩形,标记出了图像中与模板相似度较高的位置。阿强兴奋地跳了起来:“找到了!终于找到了!我就知道 CNN 不会让我失望的!”

他仔细查看这些标记的位置,发现有几个地方的身形和衣着特征与盗贼的模板非常相似。阿强立刻把这些信息整理成报告,发送给了警方。

第四章:真相大白 —— 阿强的 “英雄时刻”
几天后,警方传来了好消息:他们根据阿强提供的线索,成功抓获了盗贼,找回了被盗的古画。博物馆为了感谢阿强,特意举办了一场盛大的颁奖典礼,阿强一下子成了当地的名人。

“阿强,你可真是我们的大英雄啊!” 博物馆馆长握着阿强的手,激动地说道。

阿强不好意思地挠挠头:“其实我也没做什么,主要是 OpenCvSharp 和 CNN 的功劳。”

从那以后,阿强更加痴迷于 OpenCvSharp 和 CNN 的研究。他知道,这只是他在图像世界里的一次小小冒险,未来还有更多的挑战和惊喜等待着他。而他,也将继续用科技的力量,去探索这个神秘而又充满魅力的图像世界。

相关文章:

C# OpenCV机器视觉:利用CNN实现快速模板匹配

在一个阳光灿烂的周末&#xff0c;阿强正瘫在沙发上&#xff0c;百无聊赖地换着电视频道。突然&#xff0c;一则新闻吸引了他的注意&#xff1a;某博物馆里一幅珍贵的古画离奇失踪&#xff0c;警方怀疑是被一伙狡猾的盗贼偷走了&#xff0c;现场只留下一些模糊不清的监控画面&a…...

消息队列篇--通信协议扩展篇--二进制编码(ASCII,UTF-8,UTF-16,Unicode等)

1、ASCII&#xff08;American Standard Code for Information Interchange&#xff09; 范围&#xff1a;0 到 127&#xff08;共 128 个字符&#xff09;描述&#xff1a;ASCII 是一种早期的字符编码标准&#xff0c;主要用于表示英文字母、数字和一些常见的符号。每个字符占…...

Direct Preference Optimization (DPO): 一种无需强化学习的语言模型偏好优化方法

论文地址&#xff1a;https://arxiv.org/pdf/2305.18290 1. 背景与挑战 近年来&#xff0c;大规模无监督语言模型&#xff08;LM&#xff09;在知识获取和推理能力方面取得了显著进展&#xff0c;但如何精确控制其行为仍是一个难题。 现有的方法通常通过**强化学习从人类反馈&…...

跟我学C++中级篇——容器的连接

一、数据的整合 在实际的开发场景中&#xff0c;经常可以遇到以下的情况&#xff1a;有几个地方的数据需要整合在一起。解决办法也有很多&#xff0c;在不同的层面有不同的解决方式。比如经过清洗可以把非关系型数据转为关系型数据。但在底层编程的情况中会发现有几情况&#…...

java求职学习day15

多线程 1 基本概念 1.1 程序和进程的概念 &#xff08;1&#xff09;程序 - 数据结构 算法&#xff0c;主要指存放在硬盘上的可执行文件。 &#xff08;2&#xff09;进程 - 主要指运行在内存中的可执行文件。 &#xff08;3&#xff09;目前主流的操作系统都支持多进程&a…...

【脚本】如何禁用谷歌浏览器自动更新

这里写自定义目录标题 问题描述解决方法代码 问题描述 最近更新系统以后&#xff0c;发现chrome老是自己更新&#xff0c;导致我的代码也得跟着他更新&#xff0c;就跟一个拜托不掉的狗皮膏药一样。 解决方法 于是我写了一个脚本&#xff0c;以下代码都是bash代码&#xff0…...

【Linux】华为服务器使用U盘安装统信操作系统

目录 一、准备工作 1.1 下载UOS官方系统 &#xff11;.&#xff12;制作启动U盘 1.3 服务器智能管理系统iBMC 二、iBMC设置U盘启动 一、准备工作 1.1 下载UOS官方系统 服务器CPU的架构是x86-64还是aarch64&#xff09;,地址&#xff1a;统信UOS生态社区 - 打造操作系统创…...

WPF3-在xaml中引用其他程序集的名称空间

1. 如何在XAML里引用类库中的名称空间和类2. 小结 1. 如何在XAML里引用类库中的名称空间和类 首先需要记住一点&#xff1a;把类库引用到项目中是引用其中名称空间的物理基础&#xff0c;无论是C#还是XAML都是这样。 一旦将一个类库引用进程序&#xff0c;就可以引用其中的名…...

Python 在Word中添加、或删除超链接

在Word文档中&#xff0c;超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超链接&#xff0c;用户可以轻松地导航到相关信息&#xff0c;从而增强文档的互动性和可读性。本文将介绍如何使用Python在Word中添加超链接、或删除Word文档中的超…...

基于 WPF 平台使用纯 C# 实现动态处理 json 字符串

一、引言 在当今的软件开发领域&#xff0c;数据的交换与存储变得愈发频繁&#xff0c;JSON&#xff08;JavaScript Object Notation&#xff09;作为一种轻量级的数据交换格式&#xff0c;以其简洁、易读、便于解析和生成的特点&#xff0c;被广泛应用于各种应用程序中。在 W…...

「全网最细 + 实战源码案例」设计模式——单例设计模式

核心思想&#xff1a; 属于创建型设计模式&#xff0c;核心目的是确保一个类在整个程序运行期间只有一个实例&#xff0c;并提供一个全局访问点来获取该实例。 控制共享资源的访问&#xff08;如数据库链接、配置管理、日志处理器等&#xff09; 真实世界类比&#xff1a;政府…...

第01章 19 通过点数据逐级构建球体体数据的综合性小例子

用VTK库来创建一个三维图像数据&#xff08;vtkImageData&#xff09;&#xff0c;并填充标量数据以表示一个球体的体数据。球的半径为50&#xff0c;体数据的空间间隔为1.0/1000。 首先&#xff0c;我需要包含VTK的头文件&#xff0c;并且创建一个vtkImageData对象。然后&…...

CVE-2024-23897-Jenkins任意文件读取漏洞复现

content Jenkins是什么CVE-2024-23897总结修复建议 Jenkins是什么 Jenkins是一人基于Java开发的、可扩展的持续集成引擎&#xff0c;用于持续、自动地构建/测试软件项目&#xff0c;可以监控一些定时执行的任务。 官网文档&#xff1a; Jenkins是一款开源 CI&CD 软件&…...

前端react后端java实现提交antd form表单成功即导出压缩包

前端&#xff08;React Ant Design&#xff09; 1. 创建表单&#xff1a;使用<Form>组件来创建你的表单。 2. 处理表单提交&#xff1a;在onFinish回调中发起请求到后端API&#xff0c;并处理响应。 import React from react; import { Form, Input, Button } from ant…...

基于ESP32的桌面小屏幕实战[6]:环境搭建和软件基础

摘要 本文分为两部分&#xff1a;Linux开发环境搭建和软件基础。Linux开发环境搭建介绍了Ubuntu虚拟机安装及SSH、Samba配置&#xff0c;可以实现用VSCode操作虚拟机。为了后续工作&#xff0c;搭建了乐鑫ESP32 SDK环境。软件基础介绍了Linux开发常用的软件基础&#xff0c;包…...

接口(完)

大家好&#xff0c;今天我们着重来总结一下接口的知识&#xff0c;并且将接口和抽象类的区别罗列一下&#xff0c;帮助我们更好的认识抽象类和接口。 2.7 抽象类和接口的区别. 抽类和接口都是Java中多态的常见使用方式,都需要重点掌握,同时又要认清两者的区别(重要!!&#xf…...

数据结构——实验七·排序

欢迎各位大佬们来到Tubishu的博客&#x1f31f; Tubishu是一名计算机本科生&#xff0c;不定期发送一些在学校的成果供佬们消遣~希望能为佬的编程之路添砖加瓦⭐&#x1f525; 求各位大佬们垂怜&#x1f525;点赞评论一下呗&#x1f525;&#x1f525; 本文专栏 ➡️ 数据结构 …...

JVM堆空间

JVM&#xff08;Java虚拟机&#xff09;堆空间是Java内存管理的核心区域之一&#xff0c;用于存储Java对象实例。以下是关于JVM堆空间的详细介绍&#xff1a; 1. 堆空间的作用 • 存储对象实例&#xff1a;几乎所有的Java对象实例&#xff08;通过new关键字创建的对象&#xf…...

【详细】SSH公私钥认证与渗透测试攻击场景

SSH&#xff08;Secure Shell&#xff09;是一个用于远程登录和执行命令的网络协议&#xff0c;其认证方式通常有两种&#xff1a;基于密码的认证和基于公私钥的认证。本文将详细介绍SSH公私钥认证机制&#xff0c;并探讨在渗透测试场景中&#xff0c;如何利用对靶机具有读取和…...

常见的多媒体框架(FFmpeg GStreamer DirectShow AVFoundation OpenMax)

1.FFmpeg FFmpeg是一个非常强大的开源多媒体处理框架&#xff0c;它提供了一系列用于处理音频、视频和多媒体流的工具和库。它也是最流行且应用最广泛的框架&#xff01; 官方网址&#xff1a;https://ffmpeg.org/ FFmpeg 的主要特点和功能&#xff1a; 编解码器支持: FFmpe…...

C++异步future

&#x1f30e; C11异步futrue 文章目录&#xff1a; C11异步futrue future介绍     应用场景     future操作       std::async函数模版       std::packaged_task类模版       std::promise类模版 &#x1f680;future介绍 std::future是C11标准库…...

Oracle 12c 中的 CDB和PDB的启动和关闭

一、简介 Oracle 12c引入了多租户架构&#xff0c;允许一个容器数据库&#xff08;Container Database, CDB&#xff09;托管多个独立的可插拔数据库&#xff08;Pluggable Database, PDB&#xff09;。本文档旨在详细描述如何启动和关闭CDB及PDB。 二、容器数据库 (CDB) 2.1…...

Vue组件开发-使用 html2canvas 和 jspdf 库实现PDF文件导出 设置页面大小及方向

在 Vue 项目中实现导出 PDF 文件、调整文件页面大小和页面方向的功能&#xff0c;使用 html2canvas 将 HTML 内容转换为图片&#xff0c;再使用 jspdf 把图片添加到 PDF 文件中。以下是详细的实现步骤和代码示例&#xff1a; 步骤 1&#xff1a;安装依赖 首先&#xff0c;在项…...

chrome插件:网页图片高清下载

前置条件&#xff1a; 安装有chrome谷歌浏览器的电脑 使用步骤&#xff1a; 1.打开chrome扩展插件 2.点击管理扩展程序 3.加载已解压的扩展程序 4.选择对应文件夹 5.成功后会出现一个扩展小程序 6.点击对应小程序 7.输入需要访问的网址&#xff0c;点击扩展插件即可进行图片…...

汽车定速巡航

配备定速巡航功能的车型&#xff0c;一般在方向盘附近设有4~6个按键&#xff08;可能共用键位&#xff09;。 要设置定速巡航&#xff0c;不仅需要方向盘上的按键&#xff0c;还要油门配合。 设置的一般流程&#xff1a; 开关&#xff1a;类似步枪上的“保险”&#xff0c;按…...

CNN-BiLSTM卷积双向长短期记忆神经网络时间序列预测(Matlab完整源码和数据)

CNN-BiLSTM卷积双向长短期记忆神经网络时间序列预测&#xff08;Matlab完整源码和数据&#xff09; 目录 CNN-BiLSTM卷积双向长短期记忆神经网络时间序列预测&#xff08;Matlab完整源码和数据&#xff09;预测效果基本介绍 CNN-BiLSTM卷积双向长短期记忆神经网络时间序列预测一…...

WPF基础 | WPF 布局系统深度剖析:从 Grid 到 StackPanel

WPF基础 | WPF 布局系统深度剖析&#xff1a;从 Grid 到 StackPanel 一、前言二、Grid 布局&#xff1a;万能的布局王者2.1 Grid 布局基础&#xff1a;构建网格世界2.2 子元素定位与跨行列&#xff1a;布局的精细操控2.3 自适应布局&#xff1a;灵活应变的秘诀 三、StackPanel…...

14-6-2C++STL的list

(一&#xff09;list对象的带参数构造 1.list&#xff08;elem);//构造函数将n个elem拷贝给本身 #include <iostream> #include <list> using namespace std; int main() { list<int> lst(3,7); list<int>::iterator it; for(itlst.begi…...

【AI论文】Sigma:对查询、键和值进行差分缩放,以实现高效语言模型

摘要&#xff1a;我们推出了Sigma&#xff0c;这是一个专为系统领域设计的高效大型语言模型&#xff0c;其独特之处在于采用了包括DiffQKV注意力机制在内的新型架构&#xff0c;并在我们精心收集的系统领域数据上进行了预训练。DiffQKV注意力机制通过根据查询&#xff08;Q&…...

私域流量池构建与转化策略:以开源链动2+1模式AI智能名片S2B2C商城小程序为例

摘要&#xff1a;随着互联网技术的快速发展&#xff0c;流量已成为企业竞争的关键资源。私域流量池&#xff0c;作为提升用户转化率和增强用户粘性的有效手段&#xff0c;正逐渐受到企业的广泛关注。本文旨在深入探讨私域流量池构建的目的、优势及其在实际应用中的策略&#xf…...