Skip to content

Latest commit

 

History

History
91 lines (56 loc) · 3.57 KB

File metadata and controls

91 lines (56 loc) · 3.57 KB

BMN


Content

Introduction

BMN模型是百度自研,2019年ActivityNet夺冠方案,为视频动作定位问题中proposal的生成提供高效的解决方案,在PaddlePaddle上首次开源。此模型引入边界匹配(Boundary-Matching, BM)机制来评估proposal的置信度,按照proposal开始边界的位置及其长度将所有可能存在的proposal组合成一个二维的BM置信度图,图中每个点的数值代表其所对应的proposal的置信度分数。网络由三个模块组成,基础模块作为主干网络处理输入的特征序列,TEM模块预测每一个时序位置属于动作开始、动作结束的概率,PEM模块生成BM置信度图。


BMN Overview

Data Preparation

BMN的训练数据采用ActivityNet1.3提供的数据集,数据下载及准备请参考数据说明

Train

数据准备完毕后,可以通过如下两种方式启动训练:

export CUDA_VISIBLE_DEVICES=0,1,2,3
export FLAGS_eager_delete_tensor_gb=0.0
export FLAGS_fraction_of_gpu_memory_to_use=0.98
export FLAGS_fast_eager_deletion_mode=1
python train.py --model_name=BMN \
                --config=./configs/bmn.yaml \
                --log_interval=10 \
                --valid_interval=1 \
                --use_gpu=True \
                --save_dir=./data/checkpoints

bash run.sh train BMN ./configs/bmn.yaml
  • 代码运行需要先安装pandas

  • 从头开始训练,使用上述启动命令行或者脚本程序即可启动训练,不需要用到预训练模型

  • 若使用第二种方式,请在run.sh脚本文件中设置4卡训练: export CUDA_VISIBLE_DEVICES=0,1,2,3

训练策略:

  • 采用Adam优化器,初始learning_rate=0.001
  • 权重衰减系数为1e-4
  • 学习率在迭代次数达到4200的时候做一次衰减,衰减系数为0.1

Test

可通过如下两种方式进行模型评估:

python eval.py --model_name=BMN \
               --config=./configs/bmn.yaml \
               --log_interval=1 \
               --weights=$PATH_TO_WEIGHTS \
               --use_gpu=True

bash run.sh eval BMN ./configs/bmn.yaml
  • 使用run.sh进行评估时,需要修改脚本中的weights参数指定需要评估的权重。

  • 若未指定--weights参数,脚本会下载已发布模型model进行评估。

  • 上述程序会将运行结果保存在data/output/EVAL\BMN_results文件夹下,测试结果保存在data/evaluate_results/bmn_results_validation.json文件中。使用ActivityNet官方提供的测试脚本,即可计算AR@AN和AUC。具体计算过程请参考指标计算

  • 使用CPU进行评估时,请将上面的命令行或者run.sh脚本中的use_gpu设置为False。

  • 注:评估时可能会出现loss为nan的情况。这是由于评估时用的是单个样本,可能存在没有iou>0.6的样本,所以为nan,对最终的评估结果没有影响。

在ActivityNet1.3数据集下评估精度如下:

AR@1 AR@5 AR@10 AR@100 AUC
33.06 49.13 56.27 75.32 67.19%

Reference