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

相关推荐
冷冷的菜哥40 分钟前
ASP.NET Core文件分片上传
c#·asp.net·asp.net core·文件分片上传
Coovally AI模型快速验证2 小时前
无人机小目标检测新SOTA:MASF-YOLO重磅开源,多模块协同助力精度飞跃
人工智能·yolo·目标检测·机器学习·计算机视觉·无人机
爆改模型2 小时前
【Trans2025】计算机视觉|即插即用|AFANet:炸裂!图像分割新SOTA,轻松碾压传统方法!
人工智能·计算机视觉
上位机付工3 小时前
2025年了,学C#上位机需要什么条件
c#·上位机·西门子
飞翔的佩奇3 小时前
【完整源码+数据集+部署教程】骰子点数识别图像实例分割系统源码和数据集:改进yolo11-DCNV2
python·yolo·计算机视觉·数据集·yolo11·骰子点数识别图像实例分割
c#上位机3 小时前
wpf之Border
c#·wpf
海鸥_4 小时前
常见的相机模型针孔/鱼眼(Pinhole,Mei,K
计算机视觉·相机·slam
人生游戏牛马NPC1号5 小时前
学习 Android (二十) 学习 OpenCV (五)
android·opencv·学习
notfindjob5 小时前
Opencv C++ 教程-人脸识别
c++·opencv·计算机视觉