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 获得图像分类

相关推荐
꧁执笔小白꧂1 小时前
C#+VisionMaster 学习笔记(目录)-目录
c#·visionmaster
sali-tec1 小时前
C# 基于halcon的视觉工作流-章68 深度学习-对象检测
开发语言·算法·计算机视觉·重构·c#
Coding茶水间3 小时前
基于深度学习的反光衣检测系统演示与介绍(YOLOv12/v11/v8/v5模型+Pyqt5界面+训练代码+数据集)
图像处理·人工智能·深度学习·yolo·目标检测·机器学习·计算机视觉
却道天凉_好个秋7 小时前
OpenCV(四十一):SIFT关键点检测
人工智能·opencv·计算机视觉
咖啡の猫7 小时前
Python字典的查询操作
数据库·python·c#
明月照山海-7 小时前
机器学习周报二十六
人工智能·机器学习·计算机视觉
kaikaile19957 小时前
MATLAB 灰度图像的二维傅里叶变换
算法·计算机视觉·matlab
永恒-龙啸7 小时前
图像增强与滤波
图像处理·人工智能·计算机视觉
czhc11400756639 小时前
c# 1213
开发语言·数据库·c#
ʜᴇɴʀʏ9 小时前
论文阅读 SAM 3: Segment Anything with Concepts
论文阅读·人工智能·目标检测·计算机视觉·目标跟踪