网站首页 > 教程文章 正文
YOLO (You Only Look Once),由华盛顿大学的Joseph Redmon和Ali Farhadi开发的流行目标检测和图像分割模型,于2015年推出,由于其高速和准确性而迅速流行。
YOLOv2 在2016年发布,通过引入批量归一化、锚框和维度聚类来改进了原始模型。
YOLOv3 在2018年推出,进一步增强了模型的性能,使用了更高效的主干网络、多个锚点和空间金字塔池化。
YOLOv4 在2020年发布,引入了Mosaic数据增强、新的无锚检测头和新的损失函数等创新功能。
YOLOv5 进一步改进了模型的性能,并增加了新功能,如超参数优化、集成实验跟踪和自动导出到常用的导出格式。
YOLOv6 在2022年由美团开源,现在正在该公司的许多自动送货机器人中使用。
YOLOv7 在COCO关键点数据集上添加了额外的任务,如姿态估计。
YOLOv8 是Ultralytics的YOLO的最新版本。作为一种前沿、最先进(SOTA)的模型,YOLOv8在之前版本的成功基础上引入了新功能和改进,以提高性能、灵活性和效率。YOLOv8支持全范围的视觉AI任务,包括检测, 分割, 姿态估计, 跟踪, 和分类。这种多功能性使用户能够利用YOLOv8的功能应对多种应用和领域的需求。
一、效果展示
人物识别
动槙物识别
动物识别
二、VS2022
界面设计
.NET8环境
NuGet安装Yolov8Net、OpenCvSharp
引用Yolov8Net和训练模型(下期讲解如何训练自己的模型)
三、代码实现
引用dll
using Yolov8Net;
using OpenCvSharp;
using OpenCvSharp.Extensions;
选择图片
private void button1_Click(object sender, EventArgs e)
{
OpenFileDialog dialog = new OpenFileDialog();
//dialog.Multiselect = true;//该值确定是否可以选择多个文件
dialog.Title = "请选择文件";
dialog.Filter = "图像文件(*.jpg;*.jpeg)|*.jpg;*.jpeg";
if (dialog.ShowDialog() == System.Windows.Forms.DialogResult.OK)
{
string file = dialog.FileName;
textBox1.Text = file;
Mat PublicMat1 = Cv2.ImRead(file, ImreadModes.AnyColor);
pictureBox1.Image = BitmapConverter.ToBitmap(PublicMat1);
showing(file);
}
}
开始识别
private void showing(string picPath)
{
//加载模型
using var yolo = YoloV8Predictor.Create("models\\yolov8n1.onnx");
var img = SixLabors.ImageSharp.Image.Load(picPath);
//读取照片
var predictions = yolo.Predict(img);
//画图
var color = Scalar.Red;
Mat PublicMat1 = Cv2.ImRead(picPath, ImreadModes.AnyColor);
foreach (var pred in predictions)
{
var originalImageHeight = img.Height;
var originalImageWidth = img.Width;
int x = (int)Math.Round(Math.Max(pred.Rectangle.X, 0));//确保X值不小于0,如果小于0,则x等于0
int y = (int)Math.Round(Math.Max(pred.Rectangle.Y, 0));//确保Y值不小于0,如果小于0,则y等于0
int width = (int)Math.Round(Math.Min(originalImageWidth - x, pred.Rectangle.Width));
int height = (int)Math.Round(Math.Min(originalImageHeight - y, pred.Rectangle.Height));
//画方框
Cv2.Rectangle(PublicMat1, new Rect(x, y, width, height), color, 2);
// 标签文本
string text = #34;{pred.Label.Name} [{pred.Score}]";
Cv2.PutText(PublicMat1, text, new OpenCvSharp.Point(x, y - 8), HersheyFonts.HersheyTriplex, 0.6, color);
}
pictureBox2.Image = BitmapConverter.ToBitmap(PublicMat1);
}
猜你喜欢
- 2025-04-30 Ai机器视觉之口罩检测(口罩视觉检测方案)
- 2025-04-30 探索Python中的人脸识别:深入pyfacelib库
- 2025-04-30 Pytorch利用CNN卷积神经网络进行多数字(0-9)识别
- 2025-04-30 【AI&ML】如何使用Google Colaboratory进行视频处理
- 2025-04-30 自动识别影视场景中的演员(自动识别电影)
- 2025-04-30 Python编程 - 基于OpenCV实现人脸识别(实践篇)爬虫+人脸识别
- 2025-04-30 使用Python和YOLO检测车牌(python判断车牌号归属地)
- 2025-04-30 用python给图片批量打水印(python批量去水印)
- 2025-04-30 简单易懂的人脸识别!用PythonOpenCV实现(适合初学者)!附源码
- 2025-04-30 在 C# WinForms 中 OpenCvSharp 进行边缘检测:Laplacian 算子介绍
- 最近发表
-
- 高德地图经纬度坐标批量拾取(高德地图如何拾取经纬度)
- 自己会进名人堂吗?库里:希望已经得到保证 我不会放慢脚步
- ASP.NET AJAX用户界面开发工具集Q3 2015 SP1全新发布
- UI控件Telerik UI for Silverlight发布R2 2016
- 可以扣篮吗?库里:我以前绝对能扣 现在为节省体能更多选择上篮
- Chrome重大更新——可自动修改被泄漏的密码
- 库里谈三分纪录:我希望继续将这项纪录推至一种无法触碰的位置
- 12个ComfyUI必备的自定义节点(cloudflare自定义节点)
- 库里谈臂展:这真的让我很苦恼 我的身高臂展都只有6尺3寸
- Win10学院:Setup.exe命令行参数详解
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- mybatis plus page (35)
- vue @scroll (38)
- 堆栈区别 (33)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)
- redis aof rdb 区别 (33)
- 302跳转 (33)
- http method (35)
- js array splice (33)