当前位置: 首页 > news >正文

深度学习目标检测中利用脑肿瘤目标检测数据集训练识别3类’glioma_tumor’, ‘meningioma_tumor’,‘pituitary_tumor’2908张图像txt格式的脑肿瘤数据集

深度学习目标检测中利用脑肿瘤目标检测数据集训练识别3类’glioma_tumor’, ‘meningioma_tumor’,'pituitary_tumor’2908张图像txt格式的脑肿瘤数据集

该数据集已经包括3个类别

分别是:‘glioma_tumor’, ‘meningioma_tumor’,‘pituitary_tumor’
总计图片2908张图像,分辨率是513x513像素

数据集是txt格式
数据集已划分为训练集/验证集/测试集
相关YOLOv5/YOLOv6/YOLOv7/YOLOv8/YOLOv9/YOLOv10模型可直接使用

Yolov8n结果可达map50是0.854,P是0.623,R是0.817

好的,我们将使用YOLOv8来训练脑肿瘤目标检测数据集。以下是详细的步骤:

  1. 环境准备

    • 安装必要的库。
    • 下载并组织数据集。
  2. 数据预处理

    • 确认数据集的划分和标签格式。
    • 格式化标签文件以便于YOLOv8使用(如果需要)。
  3. 模型定义与训练

    • 使用YOLOv8进行目标检测。
  4. 评估与可视化

    • 评估模型性能。
    • 可视化结果。

环境准备

首先,我们需要安装必要的库。您可以使用以下命令来设置环境:

pipinstallultralytics

数据预处理

假设您的数据集已经下载并存储在datasets/brain_tumors目录中,其中包含imageslabels子目录。labels子目录中的每个.txt文件对应一个图像文件,格式为YOLOv5/YOLOv8所需的格式。

以下是确认数据集有效性和检查标签格式的脚本check_dataset.py:

[<title="Check Dataset Script for Brain Tumor Detection">]importosfrompathlibimportPath# Define pathsbase_path=Path('datasets/brain_tumors')train_images_dir=base_path/'train/images'train_labels_dir=base_path/'train/labels'val_images_dir=base_path/'val/images'val_labels_dir=base_path/'val/labels'test_images_dir=base_path/'test/images'test_labels_dir=base_path/'test/labels'# Function to check if label files exist for all imagesdefcheck_labels_exist(images_dir,labels_dir):missing_labels=[]forimg_fileinimages_dir.glob('*.jpg'):# Adjust extension if necessarylabel_file=labels_dir/(img_file.stem+'.txt')ifnotlabel_file.exists():missing_labels.append(img_file.name)returnmissing_labels# Check train setmissing_train_labels=check_labels_exist(train_images_dir,train_labels_dir)ifmissing_train_labels:print(f"Missing train labels:{missing_train_labels}")else:print("All train labels are present.")# Check val setmissing_val_labels=check_labels_exist(val_images_dir,val_labels_dir)ifmissing_val_labels:print(f"Missing val labels:{missing_val_labels}")else:print("All val labels are present.")# Check test setmissing_test_labels=check_labels_exist(test_images_dir,test_labels_dir)ifmissing_test_labels:print(f"Missing test labels:{missing_test_labels}")else:print("All test labels are present.")

创建YAML配置文件

确保您有一个正确的YAML配置文件brain_tumors.yaml来描述数据集。以下是示例配置文件:

[<title="YOLOv8 Configuration File for Brain Tumor Detection">]train:../datasets/brain_tumors/train/imagesval:../datasets/brain_tumors/val/imagesnc:3names:['glioma_tumor','meningioma_tumor','pituitary_tumor']

将上述内容保存为datasets/brain_tumors/brain_tumors.yaml

模型定义与训练

我们将使用YOLOv8进行目标检测。以下是训练脚本train_detection.py:

[<title="Training Script for Brain Tumor Detection using YOLOv8">]fromultralyticsimportYOLO# Load a modelmodel=YOLO('yolov8n.pt')# load a pretrained model (recommended for training)# Train the modelresults=model.train(data='../datasets/brain_tumors/brain_tumors.yaml',epochs=50,imgsz=513,batch=16,project='../runs/train',name='brain_tumor_detection')# Evaluate the modelmetrics=model.val()results=model.export(format='onnx')# export the trained model to ONNX format

评估与可视化

使用YOLOv8自带的评估脚本来评估目标检测模型。

[<title="Evaluation Script for Brain Tumor Detection using YOLOv8">]fromultralyticsimportYOLO# Load the best modelbest_model=YOLO('../runs/train/brain_tumor_detection/weights/best.pt')# Evaluate the model on the validation datasetmetrics=best_model.val(data='../datasets/brain_tumors/brain_tumors.yaml',conf=0.5,iou=0.45)print(metrics)

用户界面

我们将使用 PyQt5 创建一个简单的 GUI 来加载和运行模型进行实时预测。以下是用户界面脚本ui.py:

[<title="PyQt5 Main Window for Brain Tumor Detection">]importsysimportcv2importnumpyasnpfromPyQt5.QtWidgetsimportQApplication,QMainWindow,QLabel,QPushButton,QVBoxLayout,QWidget,QFileDialogfromPyQt5.QtGuiimportQImage,QPixmapfromPyQt5.QtCoreimportQt,QTimerfromultralyticsimportYOLO# Load modeldetection_model=YOLO('../runs/train/brain_tumor_detection/weights/best.pt')classMainWindow(QMainWindow):def__init__(self):super().__init__()self.setWindowTitle("脑肿瘤检测系统")self.setGeometry(100,100,800,600)self.initUI()definitUI(self):self.central_widget=QWidget()self.setCentralWidget(self.central_widget)self.layout=QVBoxLayout()self.image_label=QLabel(self)self.image_label.setAlignment(Qt.AlignCenter)self.layout.addWidget(self.image_label)self.load_image_button=QPushButton("加载图像",self)self.load_image_button.clicked.connect(self.load_image)self.layout.addWidget(self.load_image_button)self.start_prediction_button=QPushButton("开始预测",self)self.start_prediction_button.clicked.connect(self.start_prediction)self.layout.addWidget(self.start_prediction_button)self.stop_prediction_button=QPushButton("停止预测",self)self.stop_prediction_button.clicked.connect(self.stop_prediction)self.layout.addWidget(self.stop_prediction_button)self.central_widget.setLayout(self.layout)self.image_path=Noneself.timer=QTimer()self.timer.timeout.connect(self.update_frame)defload_image(self):options=QFileDialog.Options()file_name,_=QFileDialog.getOpenFileName(self,"选择图像文件","","Images (*.png *.jpg *.jpeg);;All Files (*)",options=options)iffile_name:self.image_path=file_name self.display_image(file_name)defdisplay_image(self,path):pixmap=QPixmap(path)scaled_pixmap=pixmap.scaled(self.image_label.width(),self.image_label.height(),Qt.KeepAspectRatio)self.image_label.setPixmap(scaled_pixmap)defstart_prediction(self):ifself.image_pathisnotNoneandnotself.timer.isActive():self.timer.start(30)# Update frame every 30 msdefstop_prediction(self):ifself.timer.isActive():self.timer.stop()self.image_label.clear()defupdate_frame(self):original_image=cv2.imread(self.image_path)image_rgb=cv2.cvtColor(original_image,cv2.COLOR_BGR2RGB)# Detectionresults=detection_model.predict(image_rgb,size=513,conf=0.5,iou=0.45)[0]forboxinresults.boxes.cpu().numpy():r=box.xyxy[0].astype(int)cls=int(box.cls[0])conf=box.conf[0]# Map class ID to nameclass_names=['胶质瘤','脑膜瘤','垂体瘤']class_name=class_names[cls]# Draw bounding boxcv2.rectangle(image_rgb,(r[0],r[1]),(r[2],r[3]),(0,255,0),2)# Put textfont=cv2.FONT_HERSHEY_SIMPLEX cv2.putText(image_rgb,f'{class_name}({conf:.2f})',(r[0],r[1]-10),font,0.9,(0,255,0),2)h,w,ch=image_rgb.shape bytes_per_line=ch*w qt_image=QImage(image_rgb.data,w,h,bytes_per_line,QImage.Format_RGB888)pixmap=QPixmap.fromImage(qt_image)scaled_pixmap=pixmap.scaled(self.image_label.width(),self.image_label.height(),Qt.KeepAspectRatio)self.image_label.setPixmap(scaled_pixmap)if__name__=="__main__":app=QApplication(sys.argv)window=MainWindow()window.show()sys.exit(app.exec_())

请确保将路径替换为您实际的路径。

使用说明

  1. 配置路径

    • 确保datasets/brain_tumors目录结构正确,并且包含trainvaltest子目录。
    • 确保runs/train/brain_tumor_detection/weights/best.pt是训练好的 YOLOv8 模型权重路径。
  2. 运行脚本

    • 在终端中运行check_dataset.py脚本来检查数据集的有效性。
    • 在终端中运行train_detection.py脚本来训练目标检测模型。
    • 在终端中运行evaluate_detection.py来评估目标检测模型性能。
    • 在终端中运行ui.py来启动 GUI 应用程序。
  3. 注意事项

    • 确保所有必要的工具箱已安装,特别是ultralyticsPyQt5
    • 根据需要调整参数,如epochsbatch_size

示例

假设您的数据文件夹结构如下:

datasets/ └── brain_tumors/ ├── train/ │ ├── images/ │ └── labels/ ├── val/ │ ├── images/ │ └── labels/ └── test/ ├── images/ └── labels/

并且每个数据集中包含相应的图像和标签文件。运行ui.py后,您可以点击按钮来加载图像并进行脑肿瘤检测。

http://www.zskr.cn/news/1511041.html

相关文章:

  • 泉盛UV-K5/K6固件深度探索:解锁专业无线电的终极潜能
  • League-Toolkit:英雄联盟玩家的智能本地化效率革命
  • Onekey Steam Depot清单下载工具:三步获取完整游戏清单的终极指南
  • FbxFormatConverter架构解析:FBX文件格式转换的技术实现与性能优化
  • 2026 佛山黄金回收机构盘点 权威鉴定团队 全品类黄金一站式回收 - 奢侈品回收测评
  • 128.配置qt(交叉)编译的路径---解决无法编译的问题
  • 终极防撤回神器:Android免Root防撤回完全指南
  • 亚马逊家具卖家,为什么一定要做CPF气候友好绿标?
  • VMware ESXi macOS解锁实战教程:在虚拟化平台运行苹果系统的完整方案
  • 2026年6月最新| 杭州注册公司代办哪家靠谱?避开这3个低价陷阱 - 商业新知
  • 5分钟掌握Bebas Neue字体:设计师必备的免费商用字体解决方案
  • 2026年目的地婚礼实战攻略:纪梵希旅拍从三亚婚纱照到新疆旷野的一站式婚礼旅拍方案深度拆解 - 深度智识库
  • 5分钟快速上手:Unity游戏汉化神器XUnity.AutoTranslator终极指南
  • 从推荐系统到A/B测试:聊聊MCMC在互联网公司里的那些‘隐形’应用
  • 数据科学与大数据技术专业学习数据分析的价值
  • 终极指南:3步轻松提取Xbox Game Pass游戏存档,实现跨平台进度迁移
  • 纯PHP单文件成绩工资查询工具:Excel直读、无数据库、手机电脑都能用
  • SpringAI配置使用类openai大模型规范
  • 2026年 平谷区长途搬家推荐榜单:专业打包全程保险、省心无忧的跨城搬迁优选! - 企业推荐官【官方】
  • NXP 22W无线快充方案解析:MWCT101x芯片与MP-A11拓扑实战指南
  • Vin象棋:3步快速上手的智能象棋助手,免费开源让普通玩家享受大师级分析体验
  • 微信好友批量添加神器:3分钟掌握Python自动化操作,效率提升10倍!
  • QueryExcel:如何用C和NPOI库实现10倍效率的多Excel文件批量查询工具
  • 天津GEO优化运营:让企业品牌在AI时代获得主动推荐 - 资讯焦点
  • 深度解析LayerDivider:AI驱动的智能图像分层技术终极指南
  • QorIQ P5020/P5010处理器:DPAA架构如何实现网络数据包处理硬件加速
  • RDMA连接管理API实战:带编译脚本的客户端-服务端通信双例
  • 怎样高效使用开源鼠标连点器:5大实战技巧与专业配置方案
  • 如何解锁QQ音乐加密格式?qmcdump工具使用指南
  • 3步解决VMware ESXi macOS限制:终极解锁实践指南