English | 简体中文
- 分布式训练指的是将训练任务按照一定方法拆分到多个计算节点进行计算,再按照一定的方法对拆分后计算得到的梯度等信息进行聚合与更新。飞桨分布式训练技术源自百度的业务实践,在自然语言处理、计算机视觉、搜索和推荐等领域经过超大规模业务检验。分布式训练的高性能,是飞桨的核心优势技术之一,PaddleDetection同时支持单机训练与多机训练。更多关于分布式训练的方法与文档可以参考:分布式训练快速开始教程。
- 以PP-YOLOE-s为例,本地准备好数据之后,使用
paddle.distributed.launch
或者fleetrun
的接口启动训练任务即可。下面为运行脚本示例。
fleetrun \
--selected_gpu 0,1,2,3,4,5,6,7 \
tools/train.py -c configs/ppyoloe/ppyoloe_crn_s_300e_coco.yml \
--eval &>logs.txt 2>&1 &
- 相比单机训练,多机训练时,只需要添加
--ips
的参数,该参数表示需要参与分布式训练的机器的ip列表,不同机器的ip用逗号隔开。下面为运行代码示例。
ip_list="10.127.6.17,10.127.5.142,10.127.45.13,10.127.44.151"
fleetrun \
--ips=${ip_list} \
--selected_gpu 0,1,2,3,4,5,6,7 \
tools/train.py -c configs/ppyoloe/ppyoloe_crn_s_300e_coco.yml \
--eval &>logs.txt 2>&1 &
注:
- 不同机器的ip信息需要用逗号隔开,可以通过
ifconfig
或者ipconfig
查看。 - 不同机器之间需要做免密设置,且可以直接ping通,否则无法完成通信。
- 不同机器之间的代码、数据与运行命令或脚本需要保持一致,且所有的机器上都需要运行设置好的训练命令或者脚本。最终
ip_list
中的第一台机器的第一块设备是trainer0,以此类推。 - 不同机器的起始端口可能不同,建议在启动多机任务前,在不同的机器中设置相同的多机运行起始端口,命令为
export FLAGS_START_PORT=17000
,端口值建议在10000~20000
之间。
- 在3机8卡V100的机器上进行模型训练,不同模型的精度、训练耗时、多机加速比情况如下所示。
模型 | 数据集 | 配置 | 单机8卡耗时/精度 | 3机8卡耗时/精度 | 加速比 |
---|---|---|---|---|---|
PP-YOLOE-s | Objects365 | ppyoloe_crn_s_300e_coco.yml | 301h/- | 162h/17.7% | 1.85 |
PP-YOLOE-l | Objects365 | ppyoloe_crn_l_300e_coco.yml | 401h/- | 178h/30.3% | 2.25 |
- 在4机8卡V100的机器上进行模型训练,不同模型的精度、训练耗时、多机加速比情况如下所示。
模型 | 数据集 | 配置 | 单机8卡耗时/精度 | 4机8卡耗时/精度 | 加速比 |
---|---|---|---|---|---|
PP-YOLOE-s | COCO | ppyoloe_crn_s_300e_coco.yml | 39h/42.7% | 13h/42.1% | 3.0 |
PP-YOLOE-m | Objects365 | ppyoloe_crn_m_300e_coco.yml | 337h/- | 112h/24.6% | 3.0 |
PP-YOLOE-x | Objects365 | ppyoloe_crn_x_300e_coco.yml | 464h/- | 125h/32.1% | 3.4 |
- 注意
- 在训练的GPU卡数过多时,精度会稍微有所损失(1%左右),此时可以尝试通过添加warmup或者适当增加迭代轮数来弥补精度损失。
- 这里的配置文件均提供的是COCO数据集的配置文件,如果需要训练其他的数据集,需要修改数据集路径。
- 上面的
PP-YOLOE
系列模型在多机训练过程中,均设置单卡batch size为8,同时学习率相比于单机8卡保持不变。