首页 游戏 软件 资讯 排行榜 专题
首页
AI
基于Paddle工具链:ROS目标检测部署方案

基于Paddle工具链:ROS目标检测部署方案

热心网友
69
转载
2025-07-24
FSACOCO数据集由北理工无人驾驶方程式车队搭建,用于中国大学生无人驾驶赛事视觉部分,含42张带标注的红蓝锥桶图像。介绍了两种基于飞桨的训练方式:PaddleDetection需克隆仓库、改参数等,PPYOLO v2训练后mAP50达99.01%;PaddleX则通过低代码完成全流程。两者均涉及模型导出与部署,可参考BITFSD开源3.0。

基于paddle工具链:ros目标检测部署方案 - 游乐网

数据集介绍

FSACOCO 数据集由 北京理工大学无人驾驶方程式车队 进行搭建并维护,致力于中国大学生无人驾驶方程式赛事中视觉部分的应用,该项赛事使用红蓝锥桶代表赛道边界,参赛队伍需要在未知地图的条件下得到最快圈时,同类数据集可参考FSOCO ,由苏黎世联邦理工学院AMZ车队进行维护,为德国大学生无人驾驶方程式大赛视觉部分数据集。
此项目作为北京理工大学无人驾驶方程式车队FSD开源3.0中目标检测模块进行展示基于Paddle工具链:ROS目标检测部署方案 - 游乐网        

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

解压数据集

数据集格式:
-dataset_sample
  |-Annotations
  |-0.xml
  |-1.xml
  |-10.xml
  |-...
  |-JPEGImage
  |-0.webp
  |-1.webp
  |-10.webp
  |-...
  |-eval.txt
  |-labels.txt
  |-train.txt
注: 此处仅提供42张数据
更多数据集可以前往https://github.com/bitfsd/FSACOCO获取

In [ ]
!unzip data/data126556/dataset_sample.zip -d ./dataset_sample
登录后复制    

方式一

使用PaddleDetection训练

PaddleDetection为基于飞桨PaddlePaddle的端到端目标检测套件,提供多种主流目标检测、实例分割、跟踪、关键点检测算法,配置化的网络模块组件、数据增强策略、损失函数等,推出多种服务器端和移动端工业级SOTA模型,并集成了模型压缩和跨平台高性能部署能力,帮助开发者更快更好完成端到端全开发流程。

特性

模型丰富: 包含目标检测、实例分割、人脸检测等100+个预训练模型,涵盖多种全球竞赛冠军方案使用简洁: 模块化设计,解耦各个网络组件,开发者轻松搭建、试用各种检测模型及优化策略,快速得到高性能、定制化的算法。端到端打通: 从数据增强、组网、训练、压缩、部署端到端打通,并完备支持云端/边缘端多架构、多设备部署。高性能: 基于飞桨的高性能内核,模型训练速度及显存占用优势明显。支持FP16训练, 支持多机训练。

模型性能概览
各模型结构和骨干网络的代表模型在COCO数据集上精度mAP和单卡Tesla V100上预测速度(FPS)对比图。基于Paddle工具链:ROS目标检测部署方案 - 游乐网        

1.克隆PaddleDetection

由于原始仓库为github链接,下载较慢,可以更换为gitee链接

In [ ]
!git clone https://gitee.com/Feng1909/PaddleDetection.git
登录后复制    

2.安装PaddleDetection的依赖

In [ ]
!pip install -r PaddleDetection/requirements.txt
登录后复制    

3.修改各种参数,如路径等

以训练PPYOLO v2为例
同理可以训练所有PaddleDetection支持的模型

修改数据集路径

PaddleDetection/configs/datasets/voc.yaml

修改为以下路径

metric: VOCmap_type: 11pointnum_classes: 3TrainDataset:  !VOCDataSet    dataset_dir: ./    anno_path: ./dataset_sample/train.txt    label_list: ./dataset_sample/labels.txt    data_fields: ['image', 'gt_bbox', 'gt_class', 'difficult']EvalDataset:  !VOCDataSet    dataset_dir: ./    anno_path: ./dataset_sample/eval.txt    label_list: ./dataset_sample/labels.txt    data_fields: ['image', 'gt_bbox', 'gt_class', 'difficult']TestDataset:  !ImageFolder    anno_path: ./dataset_sample/labels.txt
登录后复制    

4.训练

In [ ]
# 从头开始训练,大约需要30分钟# bbox mAP50能达到99.01%!python PaddleDetection/tools/train.py -c PaddleDetection/configs/ppyolo/ppyolov2_r50vd_dcn_voc.yml --use_vdl=true --eval# 中途中断,继续训练,更改output/ppyolov2_r50vd_dcn_voc/248.pdparams为中断前的模型参数# !python PaddleDetection/tools/train.py -c PaddleDetection/configs/ppyolo/ppyolov2_r50vd_dcn_voc.yml -r output/ppyolov2_r50vd_dcn_voc/248.pdparams --use_vdl=true --eval
登录后复制    

5.模型导出

若需使用TensorRT进行加速,则TestReader.inputs_def.image_shape为必需项目

In [ ]
!python PaddleDetection/tools/export_model.py -c PaddleDetection/configs/ppyolo/ppyolov2_r50vd_dcn_voc.yml --output_dir=./inference_model \ -o weights=output/ppyolov2_r50vd_dcn_voc/best_model # TestReader.inputs_def.image_shape=[3,640,640]
登录后复制    

6.模型部署

参见BITFSD开源3.0

经过完整数据集训练后PPYOLO v2识别效果

基于Paddle工具链:ROS目标检测部署方案 - 游乐网        

方式二 使用PaddleX训练

PaddleX 集成飞桨智能视觉领域图像分类、目标检测、语义分割、实例分割任务能力,将深度学习开发全流程从数据准备、模型训练与优化到多端部署端到端打通,并提供统一任务API接口及图形化开发界面Demo。开发者无需分别安装不同套件,以低代码的形式即可快速完成飞桨全流程开发。

1.安装PaddleX

In [ ]
!pip install paddlex==2.1
登录后复制    

2.设置环境

In [18]
# 设置使用0号GPU卡(如无GPU,执行此代码后仍然会使用CPU训练模型)import matplotlibmatplotlib.use('Agg') import osos.environ['CUDA_VISIBLE_DEVICES'] = '0'import paddlex as pdx
登录后复制    

3.设置数据集增强

In [ ]
from paddlex import transforms as Ttrain_transforms = T.Compose([    T.MixupImage(mixup_epoch=-1), T.RandomDistort(),    T.RandomExpand(im_padding_value=[123.675, 116.28, 103.53]), T.RandomCrop(),    T.RandomHorizontalFlip(), T.BatchRandomResize(        target_sizes=[192, 224, 256, 288, 320, 352, 384, 416, 448, 480, 512],        interp='RANDOM'), T.Normalize(            mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225])])eval_transforms = T.Compose([    T.Resize(        target_size=320, interp='CUBIC'), T.Normalize(            mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225])])
登录后复制    

4.设置数据集读取

In [ ]
import paddlex as pdxtrain_dataset = pdx.datasets.VOCDetection(    data_dir='dataset_sample',    file_list='dataset_sample/train.txt',    label_list='dataset_sample/labels.txt',    transforms=train_transforms,    shuffle=True)eval_dataset = pdx.datasets.VOCDetection(    data_dir='dataset_sample',    file_list='dataset_sample/eval.txt',    label_list='dataset_sample/labels.txt',    transforms=eval_transforms)
登录后复制    

5.训练

In [ ]
num_classes = len(train_dataset.labels)# model = pdx.det.YOLOv3(num_classes=num_classes)# model = pdx.det.PPYOLO(num_classes=num_classes)model = pdx.det.PPYOLOv2(num_classes=num_classes)model.train(    num_epochs=550,    train_dataset=train_dataset,    train_batch_size=24,    eval_dataset=eval_dataset,    pretrain_weights=None,    learning_rate=0.000125,    warmup_steps=100,    warmup_start_lr=0.0,    lr_decay_epochs=[130, 540],    lr_decay_gamma=.5,    early_stop=True,    save_interval_epochs=20,    save_dir='output/ppyolov2',    # resume_checkpoint='output/yolov3/epoch_430',    use_vdl=True)
登录后复制    

6.模型导出

若需使用TensorRT加速,则--fixed_input_shape为必需项

In [ ]
!paddlex --export_inference --model_dir=./output/ppyolov2/best_model/ \                            --save_dir=./inference_model # --fixed_input_shape=[224,224]
登录后复制    

7.模型部署

参见BITFSD开源3.0

来源:https://www.php.cn/faq/1425331.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

openclaw在飞书测试报错access not configured.
AI
openclaw在飞书测试报错access not configured.

常见报错解析:“Access Not Configured”故障排除指南 许多开发者和团队成员在使用OpenClaw集成飞书时,都曾遭遇过一个典型的中断提示:“access not configured”(访问未配置)。该提示会明确显示您的飞书账户ID及一组唯一的配对验证码,并指出需要联系机器人所有

热心网友
04.02
OpenClaw 常用指令速查
AI
OpenClaw 常用指令速查

OpenClaw 常用指令大全与使用详解 openclaw status:此命令是查看OpenClaw系统整体健康状态的核心指令,执行后即获取服务运行状况的全面报告,是日常运维的首要诊断工具。 openclaw gateway restart:在修改网关配置后,必须运行此指令以重启网关服务,使配置文

热心网友
04.02
OpenClaw 操控浏览器
AI
OpenClaw 操控浏览器

如何通过 OpenClaw 实现 Chrome 浏览器自动化操控 在软件开发与自动化测试领域,持续学习是常态。本文旨在详细介绍如何利用 OpenClaw 连接并控制一个已开启的 Chrome 浏览器实例,实现点击、文本输入、文件上传、页面滚动、屏幕截图以及执行 JavaScript 等自动化操作。整

热心网友
04.01
# OpenClaw QQ 机器人接入完整指南
AI
# OpenClaw QQ 机器人接入完整指南

项目概述 你是否希望将强大的 AI 助手带入日常聊天?本教程将指导你完成搭建流程,让你能在 QQ 上直接调用 OpenClaw 智能助手,实现无门槛的 AI 对话体验。 架构说明 ┌─────────────┐ ┌──────────────┐ ┌─────────────┐ │ QQ 用户 │ ─

热心网友
04.01
OpenClaw 保姆级 window部署
AI
OpenClaw 保姆级 window部署

一 下载并安装Node js,全程保持默认设置 首先,请前往Node js官方网站的下载中心:https: nodejs org zh-cn download。根据您的操作系统(Windows Mac Linux)下载对应的安装程序。运行安装向导时,整个过程非常简单,您只需连续点击“下一步”按钮

热心网友
04.01

最新APP

火柴人传奇
火柴人传奇
动作冒险 04-01
街球艺术
街球艺术
体育竞技 04-01
飞行员模拟
飞行员模拟
休闲益智 04-01
史莱姆农场
史莱姆农场
休闲益智 04-01
绝区零
绝区零
角色扮演 04-01

热门推荐

判断流浪动物是否友好时以下哪种信号是错误的
游戏攻略
判断流浪动物是否友好时以下哪种信号是错误的

支付宝蚂蚁庄园2026年4月4日今日最新答案揭晓 今日蚂蚁庄园小课堂的首道题目是:在判断流浪动物是否友善时,以下哪一种信号解读是不正确的? A、狗狗摇尾巴就一定代表友好 B、瞳孔放大通常表示恐惧 正确答案 狗狗摇尾巴就一定代表友好 详细解析 许多人存在一个普遍误区,认为犬类摇尾巴一定是开心和亲近的信

热心网友
04.04
他趣如何结婚
手机教程
他趣如何结婚

他趣:如何从真诚交友顺利走向婚姻殿堂 他趣并非直接促成婚姻的魔法钥匙,但它确实扮演着至关重要的角色——为众多单身人士搭建了一座从线上认识到线下相恋,最终携手步入婚姻的可靠桥梁。这个平台汇聚了真实且有婚恋意图的用户,让原本可能无缘相遇的两个人,有了相识、相知直至相守的珍贵机会。 第一步:完善个人资料,

热心网友
04.04
洛克王国世界必入手宠物与技能搭配推荐指南
游戏攻略
洛克王国世界必入手宠物与技能搭配推荐指南

洛克王国世界开荒攻略:首日必抓精灵与阵容搭配详解 《洛克王国世界》开服第一天,所有训练师的核心目标非常明确:高效利用初期时间,组建一套既能轻松探索地图,又能平稳应对各类战斗的精灵队伍。选择正确的开荒阵容,能让你的冒险之旅事半功倍;若选择不当,则可能陷入被动,浪费宝贵资源。那么,哪些宠物是玩家公认的“

热心网友
04.04
洛克王国世界精灵克制关系指南
游戏攻略
洛克王国世界精灵克制关系指南

洛克王国全属性克制关系解析:掌握十八系胜负关键 进入洛克王国,你将探索一个由18种精灵属性构成的丰富对战世界:普通、草、火、水、光、地、冰、龙、电、毒、虫、武、翼、萌、幽、恶、机械与幻系。各属性之间存在着复杂而精准的克制与抵抗规则,这对新手玩家而言可能显得纷繁复杂。本文旨在全面解析洛克王国属性克制表

热心网友
04.04
佣兵小镇乔丝琳怎么获得?佣兵小镇乔丝琳养成攻略
游戏攻略
佣兵小镇乔丝琳怎么获得?佣兵小镇乔丝琳养成攻略

光系核心英雄乔丝琳养成全攻略:从获取到毕业的深度指南 一、乔丝琳获取途径与资源投入规划 作为光系核心输出英雄,乔丝琳的获取时机非常明确,她将在服务器开区第3天通过专属转盘活动正式登场。玩家需要为其规划清晰的培养路径:起步品质建议至少达到红2,而终极目标则是彩4完全体毕业。 大额投入方案(适合追求极速

热心网友
04.04