太原市建设局网站做外贸网站怎么设计
太原市建设局网站,做外贸网站怎么设计,中国十大网络公司排名,郑州一建集团有限公司官网智慧化移动工具-输电线路三维全景智能检测数据集#xff0c;输电线路防外力破坏。
实时精准识别危险车辆#xff0c;山火烟雾。
YOLO格式2768张#xff0c;5个类别。
标注类别名称:[“Excavator-挖掘机”,“Loader-推土机”,“Dumb_truck-装载车/渣土车”,“Mobile_cra…智慧化移动工具-输电线路三维全景智能检测数据集输电线路防外力破坏。实时精准识别危险车辆山火烟雾。YOLO格式2768张5个类别。标注类别名称:[“Excavator-挖掘机”,“Loader-推土机”,“Dumb_truck-装载车/渣土车”,“Mobile_crane-吊车”,“hzyw-火灾烟雾”]使用标注工具labelImg1 输电线路防外力破坏智能检测数据集YOLO 格式项目内容数据集名称智慧化移动工具——输电线路三维全景智能检测数据集应用场景输电线路防外力破坏施工机械入侵 山火烟雾监测总图像数量2,768 张高清图像标注格式YOLO.txt每张图对应一个标签文件标注工具LabelImg图像来源无人机航拍、固定监控摄像头、移动巡检设备多角度、多光照、多天气分辨率范围1920×1080 至 4096×2160原始高清训练时统一缩放至 640×640数据划分建议- 训练集2,214 张80%- 验证集277 张10%- 测试集277 张10% 类别定义与分布统计类别编号class_id类别名称中文类别名称英文/标签名说明示例场景0挖掘机Excavator工程机械常出现在线路下方施工建筑工地、道路开挖1推土机Loader大型推土/铲运设备土方工程、场地平整2装载车 / 渣土车Dumb_truck运输渣土、砂石的重型车辆建筑垃圾运输、夜间偷倒3吊车Mobile_crane可伸缩吊臂的移动式起重机电力施工、违规吊装作业4火灾烟雾hzyw山火、秸秆焚烧产生的烟雾林区、农田周边起火✅注所有类别均为“危险源”一旦识别即触发预警。hzyw火灾烟雾为非刚性目标需模型具备良好泛化能力。标签文件中类别索引从0开始与上述编号一致。 数据集目录结构建议YOLO 格式transmission_line_dataset/ ├── images/ │ ├── train/ │ │ ├── img_0001.jpg │ │ └──... │ ├── val/ │ └── test/ ├── labels/ │ ├── train/ │ │ ├── img_0001.txt │ │ └──... │ ├── val/ │ └── test/ └── dataset.yamldataset.yaml配置文件示例# transmission_line_dataset/dataset.yamlpath:./transmission_line_datasettrain:images/trainval:images/valtest:images/testnc:5names:[Excavator,Loader,Dumb_truck,Mobile_crane,hzyw]⚠️ 标注注意事项来自 LabelImg使用矩形框Bounding Box精准包围目标主体。对于部分遮挡或远距离小目标仍需标注提升模型鲁棒性。烟雾目标应标注其可见烟柱主体区域避免包含过多天空背景。同一图像中允许多个同类或不同类目标共存。 应用价值功能说明实时预警在监控视频流中实时识别危险机械或烟雾自动告警️防外破防止施工机械误碰高压线保障电网安全山火防控早期发现烟雾联动消防系统快速响应智能巡检替代人工巡线降低运维成本提升效率以下是针对您提供的输电线路防外力破坏智能检测数据集5 类挖掘机、推土机、渣土车、吊车、火灾烟雾的完整 YOLOv8 训练代码与部署流程包含✅ 数据集准备✅dataset.yaml配置✅ 模型训练脚本✅ 验证与测试✅ 导出 ONNX / TensorRT可选✅ 推理示例图片 视频 摄像头 使用框架Ultralytics YOLOv8官方 PyTorch 实现 依赖Python ≥3.8, torch ≥1.8, ultralytics✅ 一、环境安装# 创建虚拟环境推荐conda create -n yolov8python3.9-y conda activate yolov8# 安装 PyTorch根据 CUDA 版本选择pipinstalltorch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118# 安装 Ultralytics YOLOv8pipinstallultralytics# 验证安装yolo version✅ 二、数据集目录结构确保您的数据集按如下结构组织YOLO 标准格式transmission_line_dataset/ ├── images/ │ ├── train/# 2214 张│ ├── val/# 277 张│ └── test/# 277 张└── labels/ ├── train/ ├── val/ └── test/ 图像格式.jpg或.png️ 标签格式每个.txt文件包含多行每行格式为class_id center_x center_y width height归一化到 [0,1]✅ 三、创建dataset.yaml在项目根目录下创建transmission_line_dataset/dataset.yaml# transmission_line_dataset/dataset.yamlpath:./transmission_line_dataset# 数据集根路径train:images/train# 训练集图像路径相对 pathval:images/val# 验证集test:images/test# 测试集可选# 类别数量和名称nc:5names:[Excavator,Loader,Dumb_truck,Mobile_crane,hzyw]⚠️ 注意路径是相对path的子路径names顺序必须与标注时的class_id严格对应✅ 四、训练代码train.py# train.pyfromultralyticsimportYOLOdefmain():# 1. 加载预训练模型YOLOv8s也可选 n/m/l/xmodelYOLO(yolov8s.pt)# 自动从 Ultralytics 官网下载# 2. 开始训练resultsmodel.train(datatransmission_line_dataset/dataset.yaml,# 数据集配置epochs100,# 训练轮数imgsz640,# 输入图像尺寸batch16,# 批大小根据 GPU 显存调整nametransmission_line_yolov8s,# 实验名称保存在 runs/detect/ 下cacheTrue,# 缓存图像加速训练device0,# GPU 设备 ID0,1,... 或 cpuworkers8,# 数据加载线程数patience15,# 早停验证损失不再下降 15 轮后停止saveTrue,# 保存最佳和最后模型exist_okFalse,# 若实验名已存在则报错verboseTrue# 打印详细日志)print(✅ 训练完成模型保存在,results.save_dir)if__name____main__:main() 训练启动命令替代方式也可以直接使用命令行无需写 Python 脚本yolo detect train\datatransmission_line_dataset/dataset.yaml\modelyolov8s.pt\epochs100\imgsz640\batch16\nametransmission_line_yolov8s\cacheTrue\device0✅ 五、验证与测试1. 验证模型性能# validate.pyfromultralyticsimportYOLO modelYOLO(runs/detect/transmission_line_yolov8s/weights/best.pt)metricsmodel.val(datatransmission_line_dataset/dataset.yaml)print(metrics.box.map)# mAP0.5:0.952. 测试单张图像# predict_image.pyfromultralyticsimportYOLOimportcv2 modelYOLO(runs/detect/transmission_line_yolov8s/weights/best.pt)resultsmodel(test_image.jpg)# 保存带框结果results[0].save(filenameoutput.jpg)# 打印检测结果forboxinresults[0].boxes:clsint(box.cls.item())conffloat(box.conf.item())print(f类别:{model.names[cls]}, 置信度:{conf:.2f})✅ 六、实时检测视频 / 摄像头# realtime_detect.pyfromultralyticsimportYOLOimportcv2 modelYOLO(runs/detect/transmission_line_yolov8s/weights/best.pt)# 选项1摄像头capcv2.VideoCapture(0)# 选项2视频文件# cap cv2.VideoCapture(construction_site.mp4)whileTrue:ret,framecap.read()ifnotret:breakresultsmodel(frame,conf0.4)# 置信度阈值 0.4annotated_frameresults[0].plot()cv2.imshow(Transmission Line Monitor,annotated_frame)ifcv2.waitKey(1)0xFFord(q):breakcap.release()cv2.destroyAllWindows()✅ 七、模型导出ONNX / TensorRT用于部署到边缘设备如 Jetson、服务器推理# 导出 ONNXyoloexportmodelruns/detect/transmission_line_yolov8s/weights/best.ptformatonnx# 导出 TensorRT需安装 tensorrtyoloexportmodelruns/detect/transmission_line_yolov8s/weights/best.ptformatengine导出后文件位于同目录下best.onnx或best.engine✅ 八、训练结果说明训练完成后结果保存在runs/detect/transmission_line_yolov8s/ ├── weights/ │ ├── best.pt ← 最佳模型按 val mAP 选择 │ └── last.pt ← 最后一轮模型 ├── results.csv ← 训练指标loss, mAP 等 ├── confusion_matrix.png └── labels.jpg ← 标签分布可视化✅ 九、性能优化建议问题建议小目标如远处吊车漏检启用mosaic1.0,scale0.5, 或使用yolov8m烟雾误检增加负样本无烟雾图像或使用 Focal Loss训练慢减小imgsz512或使用yolov8n过拟合增加augment默认已开启或添加更多数据✅ 十、附类别映射表供前端/数据库使用class_id类别名称风险等级预警动作0Excavator挖掘机高危立即告警 定位1Loader推土机高危告警 视频录制2Dumb_truck渣土车中危记录 提醒巡检3Mobile_crane吊车极高危紧急告警 联动断电模拟4hzyw火灾烟雾紧急火警联动 通知消防✅提示若需Flask Web 系统集成可将best.pt加载到 Flask 后端提供 API。若需批量检测 PDF 报告可结合reportlab库生成。