基于yolov26+pyqt5的药片胶囊计数系统python源码+pytorch模型+精美GUI界面
【效果展示】

【训练数据集介绍】
数据集格式:YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的yolo格式txt文件)
图片数量(jpg文件个数):2017
标注数量(txt文件个数):2017
训练集数量:1804
验证集数量:135
测试集数量:78
标注类别数:2
所在github仓库:firc-dataset
标注类别名称(注意yolo格式类别顺序不和这个对应,而以labels文件夹classes.txt为准):['jiaonang','yaopian']
每个类别标注的框数:
jiaonang 框数=15854
yaopian 框数=25381
总框数=41235
使用标注工具:labelImg
标注规则:对类别进行画矩形框
重要说明:数据集大约1100是原图剩余为旋转增强生成图片
特别声明:本数据集不对训练的模型或者权重文件精度作任何保证
图片预览:
标注例子:

【测试环境】
windows10
anaconda3+python3.8
torch==2.3.1
ultralytics==8.4.31
【模型可以检测出2类别】
药片和胶囊
【训练信息】
参数值训练集图片数1804验证集图片数135训练map90.7%训练精度(Precision)85.9%训练召回率(Recall)85.7%
验证集评估精度信息:
name=map@50%
all=91
0(胶囊)=87
1(药片)=95
【常用评估参数介绍】
在目标检测任务中,评估模型的性能是至关重要的。你提到的几个术语是评估模型性能的常用指标。下面是对这些术语的详细解释:
- 1. Class :
- • 这通常指的是模型被设计用来检测的目标类别。例如,一个模型可能被训练来检测车辆、行人或动物等不同类别的对象。
- 2. Images :
- • 表示验证集中的图片数量。验证集是用来评估模型性能的数据集,与训练集分开,以确保评估结果的公正性。
- 3. Instances :
- • 在所有图片中目标对象的总数。这包括了所有类别对象的总和,例如,如果验证集包含100张图片,每张图片平均有5个目标对象,则Instances为500。
- 4. P(精确度Precision) :
- • 精确度是模型预测为正样本的实例中,真正为正样本的比例。计算公式为:Precision = TP / (TP + FP),其中TP表示真正例(True Positives),FP表示假正例(False Positives)。
- 5. R(召回率Recall) :
- • 召回率是所有真正的正样本中被模型正确预测为正样本的比例。计算公式为:Recall = TP / (TP + FN),其中FN表示假负例(False Negatives)。
- 6. mAP50 :
- • 表示在IoU(交并比)阈值为0.5时的平均精度(mean Average Precision)。IoU是衡量预测框和真实框重叠程度的指标。mAP是一个综合指标,考虑了精确度和召回率,用于评估模型在不同召回率水平上的性能。在IoU=0.5时,如果预测框与真实框的重叠程度达到或超过50%,则认为该预测是正确的。
- 7. mAP50-95 :
- • 表示在IoU从0.5到0.95(间隔0.05)的范围内,模型的平均精度。这是一个更严格的评估标准,要求预测框与真实框的重叠程度更高。在目标检测任务中,更高的IoU阈值意味着模型需要更准确地定位目标对象。mAP50-95的计算考虑了从宽松到严格的多个IoU阈值,因此能够更全面地评估模型的性能。
这些指标共同构成了评估目标检测模型性能的重要框架。通过比较不同模型在这些指标上的表现,可以判断哪个模型在实际应用中可能更有效。
【使用步骤】
使用步骤:
(1)首先根据官方框架ultralytics安装教程安装好yolo26环境,并安装好pyqt5
(2)切换到自己安装的yolo26环境后,并切换到源码目录,执行python gui.py即可运行启动界面,进行相应的操作即可
【提供文件】
python源码
pytorch模型
训练的map,P,R曲线图(在weights\results.png)
测试图片若干张(在test_img文件夹下面)
注意提供训练的数据集