首页 > 其他分享 >JPEGWD数据集,焊接缺陷检测NDT专用数据集RGB钢板焊缝缺陷识别任务和分类任务数据集(JPEGWD)1.(JPEGWD,整理更新中:分类识别检测12000张,带分类。

JPEGWD数据集,焊接缺陷检测NDT专用数据集RGB钢板焊缝缺陷识别任务和分类任务数据集(JPEGWD)1.(JPEGWD,整理更新中:分类识别检测12000张,带分类。

时间:2024-09-17 13:21:42浏览次数:21  
标签:检测 image 分类 焊接 path JPEGWD 识别 数据

项目背景:

焊接是制造业中的关键工艺之一,焊接质量的好坏直接影响到产品的安全性和可靠性。焊接缺陷检测(Non-Destructive Testing, NDT)是确保焊接质量的重要手段。传统的焊接缺陷检测方法依赖于人工目视检查,效率低下且易受主观因素影响。近年来,随着计算机视觉技术的发展,基于机器学习的方法逐渐应用于焊接缺陷的自动检测中。本数据集旨在为焊接缺陷检测提供高质量的标注数据,支持自动检测系统的开发与应用。

数据集概述:
  • 名称:JPEGWD 数据集
  • 规模:共计12,000张图像
  • 任务类型:分类识别与检测识别
  • 标注格式:带分类识别标签和检测识别标签
  • 附加内容:作者硕士期间的成果积累,包含自己的SCI论文中的线结构光焊缝数据集(LSWD)和拼接焊件焊缝数据集(1800版本,三类别检测)
数据集特点:

  1. 全面性:涵盖多种焊接缺陷类型,确保数据集的多样性和实用性。
  2. 高质量标注:每张图像都已详细标注,确保数据的准确性和可靠性。
  3. 适用范围广:适用于多种深度学习框架,方便科研人员和开发者直接使用。
  4. 学术价值:来源于作者硕士期间的研究成果,具有较高的学术参考价值。
数据集内容:
  1. 分类识别检测数据集(JPEGWD)

    • 规模:12,000张图像
    • 标注:带分类识别标签和检测识别标签
    • 用途:支持焊接缺陷的分类和检测任务
  2. 线结构光焊缝数据集(LSWD)

    • 来源:作者的SCI论文
    • 用途:支持基于线结构光的焊缝检测任务
  3. 拼接焊件焊缝数据集(1800版本)

    • 规模:1,800张图像
    • 类别:三类别检测
    • 用途:支持拼接焊件焊缝的检测任务
数据集用途:
  1. 缺陷检测:可用于训练和评估深度学习模型,特别是在焊接缺陷检测方面。
  2. 质量控制:帮助实现焊接质量的自动化检测,减少人工检测的工作量。
  3. 科研与教育:为焊接质量检测领域的研究和教学提供丰富的数据支持。
使用场景:
  1. 自动化检测:在工业生产线上,利用该数据集训练的模型可以自动识别焊接缺陷。
  2. 质量控制:在质量控制系统中,利用该数据集可以提高检测的准确性和速度。
  3. 生产管理:在生产管理和优化工作中,利用该数据集可以提高生产效率和产品质量。
技术指标:
  • 数据量:共计12,000张分类识别检测图像,1,800张拼接焊件焊缝图像。
  • 标注格式:带分类识别标签和检测识别标签。
  • 标注精度:所有图像均已详细标注,确保数据的准确性和可靠性。
注意事项:
  • 数据隐私:在使用过程中,请确保遵守相关法律法规,保护个人隐私。
  • 数据预处理:在使用前,建议进行一定的数据预处理,如图像归一化等。
获取方式:
  • 下载链接:请访问项目主页获取数据集下载链接。
  • 许可证:请仔细阅读数据集的使用许可协议。
关键代码示例:

以下是关键代码的示例,包括数据加载、模型训练、检测和结果展示。

数据加载:

python

深色版本

1import os
2import cv2
3import numpy as np
4from xml.etree import ElementTree as ET
5
6# 数据集路径
7DATASET_PATH = 'path/to/dataset'
8JPEGWD_IMAGES_DIR = os.path.join(DATASET_PATH, 'JPEGWD_images')
9JPEGWD_VOC_LABELS_DIR = os.path.join(DATASET_PATH, 'JPEGWD_voc_labels')
10JPEGWD_YOLO_LABELS_DIR = os.path.join(DATASET_PATH, 'JPEGWD_yolo_labels')
11
12# 加载数据集
13def load_dataset(directory):
14    images = []
15    voc_labels = []
16    yolo_labels = []
17
18    for img_file in os.listdir(JPEGWD_IMAGES_DIR):
19        if img_file.endswith('.jpg'):
20            img_path = os.path.join(JPEGWD_IMAGES_DIR, img_file)
21            voc_label_path = os.path.join(JPEGWD_VOC_LABELS_DIR, img_file.replace('.jpg', '.xml'))
22            yolo_label_path = os.path.join(JPEGWD_YOLO_LABELS_DIR, img_file.replace('.jpg', '.txt'))
23            
24            image = cv2.imread(img_path)
25            images.append(image)
26            
27            # 加载VOC标签
28            tree = ET.parse(voc_label_path)
29            root = tree.getroot()
30            voc_objects = []
31            for obj in root.findall('object'):
32                name = obj.find('name').text
33                bbox = obj.find('bndbox')
34                xmin = int(bbox.find('xmin').text)
35                ymin = int(bbox.find('ymin').text)
36                xmax = int(bbox.find('xmax').text)
37                ymax = int(bbox.find('ymax').text)
38                voc_objects.append((name, (xmin, ymin, xmax, ymax)))
39            voc_labels.append(voc_objects)
40            
41            # 加载YOLO标签
42            with open(yolo_label_path, 'r') as f:
43                yolo_label = f.read().strip()
44            yolo_labels.append(yolo_label)
45
46    return images, voc_labels, yolo_labels
47
48images, voc_labels, yolo_labels = load_dataset(DATASET_PATH)
模型训练:
1# 初始化YOLOv8模型
2model = YOLO('yolov8n.pt')
3
4# 定义训练参数
5EPOCHS = 100
6BATCH_SIZE = 16
7
8# 训练模型
9results = model.train(data='weld_defects.yaml', epochs=EPOCHS, batch=BATCH_SIZE)
模型检测:
1# 加载训练好的模型
2model = YOLO('best.pt')
3
4# 检测图像
5def detect_weld_defects(image):
6    results = model.predict(image)
7    for result in results:
8        boxes = result.boxes
9        for box in boxes:
10            x1, y1, x2, y2 = box.xyxy[0]
11            conf = box.conf
12            class_id = box.cls
13            
14            # 显示结果
15            cv2.rectangle(image, (int(x1), int(y1)), (int(x2), int(y2)), (0, 255, 0), 2)
16            cv2.putText(image, f'Class: {class_id}, Conf: {conf:.2f}', (int(x1), int(y1)-10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 255, 0), 2)
17    
18    return image
19
20# 测试图像
21test_image = cv2.imread('path/to/test_image.jpg')
22result_image = detect_weld_defects(test_image)
23cv2.imshow('Detected Weld Defects', result_image)
24cv2.waitKey(0)
25cv2.destroyAllWindows()
配置文件 weld_defects.yaml
1train: path/to/train/images
2val: path/to/val/images
3test: path/to/test/images
4
5nc: 3  # Number of classes for the three-category detection task
6names: ['Defect Type 1', 'Defect Type 2', 'Defect Type 3']  # Class names
7
8# Training parameters
9batch_size: 16
10epochs: 100
11img_size: [640, 640]  # Image size
使用指南:
  1. 数据准备:确保数据集路径正确,并且数据集已准备好。
  2. 模型训练:运行训练脚本,等待训练完成。
  3. 模型检测:使用训练好的模型进行检测,并查看检测结果。
结语:

本数据集提供了一个高质量的焊接缺陷检测数据集,支持自动化检测、质量控制等多个应用场景。通过利用该数据集训练的模型,可以提高焊接检测的效率和准确性。

标签:检测,image,分类,焊接,path,JPEGWD,识别,数据
From: https://blog.csdn.net/2301_78240361/article/details/142292330

相关文章

  • 短信的多样性:如何按发送与接收方式进行分类
    短信的简介短信,全称为ShortMessageService,简称SMS,是一种通过手机或其他电信终端直接发送或接收的通信服务。它最初是基于文本和数字的消息形式,但随着技术的进步,已经发展到可以支持图像、语音、视频和表情等多种类型的消息。短信的字符数限制通常为160个英文或数字字符,或者70......
  • 基于通信协议与技术架构的API接口分类探讨
    API的全称是“ApplicationProgrammingInterface”,意为“应用程序编程接口”API接口的分类:按照技术分WebAPI:基于Web的API,通过HTTP和HTTPS协议与应用程序交互,如RESTfulAPI和SOAPAPI。云API:用于在云计算环境中管理和操作云服务,例如AmazonWebServicesAPI和MicrosoftA......
  • 轻资产创业的风险识别与防范
    在当今的商业世界中,轻资产模式因其灵活性和高效性而备受企业青睐。然而,如同任何商业模式一样,轻资产模式也并非毫无风险。了解并有效防范这些风险对于企业的可持续发展至关重要。一、轻资产模式概述轻资产模式是指企业将自身的资源重点配置在研发、品牌、营销等核心环节,而将生......
  • 鹏哥C语言39---函数的分类
    #define_CRT_SECURE_NO_WARNINGS//----------------------------------------------------------------------------------------------------------第三章.函数/*1 函数是什么2 C语言中函数的分类3 函数的参数4 函数的调用5 函数的嵌套调用和链式访问6 ......
  • 惊艳不已!智能解析10个API接口分类
    常见的API接口开发平台:通信类短信API语音API彩信APIFAXAPIIVRAPITTSAPI在线客服API短信/语音验证码API定时提醒API常见的API接口开放平台:测评类API便捷数据网常见的API接口开发平台:通信类iContact、Mailgun、Mandrill、SendGrid:都是云邮件发送平台,提供易于使......
  • 基于Python的自然语言处理系列(9):使用TorchText与预训练词嵌入进行新闻分类
            在前一篇文章中,我们展示了如何使用TorchText和RNN进行新闻分类。在这篇文章中,我们将改进之前的模型,通过使用预训练词嵌入、优化器的更改、正交初始化以及打包填充序列的技巧,提升模型的学习效率和效果。1.改进方向提高模型学习效果:使用预训练词嵌入:使用Fast......
  • 基于Python的人工智能应用案例系列(2):分类
            在本篇文章中,我们将探讨分类问题,具体的应用场景是贷款审批预测。通过该案例,我们将学习如何使用Python处理分类问题,训练模型并预测贷款是否会被批准。案例背景        该数据集包含贷款申请的相关信息,目标是预测贷款是否会被批准(Loan_Status为目标变......
  • STM32入门教程:身份证识别
    身份证识别是一种常见的图像处理应用,能够通过识别身份证上的文字信息,以获取身份证号码、姓名等重要个人信息。在本教程中,我们将使用STM32微控制器和相关的图像处理算法,来实现身份证识别功能。硬件准备首先,我们需要准备一块STM32开发板,以及相应的图像传感器。你可以选择使用......
  • 【嵌入式linux开发】旭日x3派部署自己训练的yolov5模型(安全帽识别、视频流推理、yolov
    旭日x3派部署自己训练的模型(安全帽识别、视频流推理、yolov5-6.2)windows,框架pytorch,python3.7效果模型训练模型转换1、pt模型文件转onnx2、检查onnx模型3、准备校准数据4、onnx转bin上板视频流推理1、图片推理2、视频流推理效果模型训练进官网可克隆yolov5......
  • Yolov5水果分类识别+pyqt交互式界面
    Yolov5FruitsDetectorYolov5是一种先进的目标检测算法,可以应用于水果分类识别任务。结合PyQT框架,可以创建一个交互式界面,使用户能够方便地上传图片并获取水果分类结果。以下将详细阐述Yolov5水果分类识别和PyQT交互式界面的实现。Yolov5是由Ultralytics公司开......