EmguCV学习笔记 VB.Net 11.4 图像分类

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

EmguCV是一个基于OpenCV的开源免费的跨平台计算机视觉库,它向C#和VB.NET开发者提供了OpenCV库的大部分功能。

教程VB.net版本请访问: EmguCV学习笔记 VB.Net 目录-CSDN博客

教程C#版本请访问: EmguCV学习笔记 C# 目录-CSDN博客

笔者的博客网址:https://blog.csdn.net/uruseibest

教程配套文件及相关说明以及如何获得pdf教程和代码,请移步: EmguCV学习笔记

学习VB.Net知识,请移步: vb.net 教程 目录_vb中如何用datagridview-CSDN博客

学习C#知识,请移步: C# 教程 目录_c#教程目录-CSDN博客

11.4 图像分类

GoogleLeNet是由Google团队提出的一种深度卷积神经网络,它在图像分类任务中表现良好,可以处理大规模的图像数据集,并获得较高的准确率。GoogleLeNet在ILSVRC 2014图像分类比赛中取得了较好的成绩。

【代码位置:frmChapter11】Button2_Click

'图像分类:Googlenet

Private Sub Button2_Click(sender As Object, e As EventArgs) Handles Button2.Click

'字符串数组保存对象分类名称

Dim classnames() As String

'对象分类,googlenet分类文件提供了1000类对象

'将每一行(对象)加入数组

classnames = File.ReadAllLines("C:\learnEmgucv\googlenet\label.txt")

'需要测试的图像文件

Dim m As New Mat("C:\learnEmgucv\tower.jpg", ImreadModes.Color)

Dim hm As Integer = m.Height

Dim wm As Integer = m.Width

Dim net As Dnn.Net

'读取网络结构文件(bvlc_googlenet.prototxt)

'和模型参数文件(bvlc_googlenet.caffemode)

net = DnnInvoke.ReadNetFromCaffe("C:\learnEmgucv\googlenet\bvlc_googlenet.prototxt",

"C:\learnEmgucv\googlenet\bvlc_googlenet.caffemodel")

'设置后端使用OpenCV

net.SetPreferableBackend(Dnn.Backend.OpenCV)

'设置计算模型的硬件设备

net.SetPreferableTarget(Target.Cpu)

Dim blob As Mat

'转换为网络输入的blob格式

blob = DnnInvoke.BlobFromImage(m, 1.0, New Drawing.Size(224, 224), New MCvScalar(127.5, 127.5, 127.5), False, False)

'设置输入数据

net.SetInput(blob)

Dim mout As New Mat

'进行模型推理

mout = net.Forward()

'最大值

Dim maxValue As Double

'最大坐标点

Dim maxPoint As Point

'在使用Googlenet进行图像分类时,

'最大值表示是某类对象的置信度(可能性)百分比

'最大值所对应坐标x即对象序号

CvInvoke.MinMaxLoc(mout, Nothing, maxValue, Nothing, maxPoint)

CvInvoke.PutText(m, "result:" & classnames(maxPoint.X) & " " & maxValue,

New Point(10, 20), FontFace.HersheyDuplex, 0.8, New MCvScalar(0, 0, 255))

ImageBox1.Image = m

End Sub

输出结果如下图所示:

图11-1 获得图像分类

相关推荐
多巴胺与内啡肽.9 分钟前
OpenCV进阶操作:角点检测
人工智能·opencv·计算机视觉
钢铁男儿44 分钟前
C# 方法(值参数和引用参数)
java·前端·c#
audyxiao0011 小时前
人工智能顶会ICLR 2025论文分享│PointOBB-v2:更简单、更快、更强的单点监督有向目标检测
人工智能·目标检测·计算机视觉·数据挖掘·主成分分析·单点监督
charlie1145141911 小时前
编译日志:关于编译opencv带有ffmpeg视频解码支持的若干办法
opencv·ffmpeg·音视频·imx6ull·移植教程
一个会的不多的人2 小时前
C# NX二次开发:宏录制实战讲解(第一讲)
开发语言·c#
s1ckrain2 小时前
【论文阅读】HunyuanVideo: A Systematic Framework For Large Video Generative Models
论文阅读·计算机视觉·aigc
Scholar6183 小时前
序列化和反序列化
c#
罗迪尼亚的熔岩3 小时前
C# 的异步任务中, 如何暂停, 继续,停止任务
开发语言·c#
Som3B0dy3 小时前
2025年北京市职工职业技能大赛第六届信息通信行业网络安全技能大赛初赛-wp
开发语言·web安全·c#
开门儿大弟子4 小时前
opencv+opencv_contrib+cuda和VS2022编译
人工智能·opencv·计算机视觉