This repository implements a combined Boundary Aware Network (BANET) and Goal Area Network (GANET) for Argoverse II Motion Forecasting Competition. The backbone is based on the classic LaneGCN.
Step 1: clone this repository:
git clone git@github.com:ClimbingMachine/bplus.git && cd bplus
Step 2: create a virtual environment and install the dependencies:
conda create --name bplus
conda activate bplus
pip install -r requirements.txt
Step 3: pre-process the Argoverse II Motion Forecasting Dataset:
cd ArgoData
python3 data_centerline.py --root path/to/raw_Argoverse_II --split train
It is worthnoting that path/to/raw_Argoverse_II should have the following data structure:
Raw_Argoverse_II
├── train
│ ├── ffffe3df-8d26-42c3-9e7a-59de044736a0
│ └── ffffd7c4-c287-4c66-adba-0486c304a1c8
│ └── ...
├── val
│ ├── fffc6ef5-8fb4-4f20-afea-b9cb63c99182
│ └── fffadd8e-2152-4a69-8c6a-dece823071b5
│ └── ...
└── test
│ ├── fffc1965-9f9e-4822-ade7-750d87c4b7b9
│ └── fffa6540-a436-40ac-8cb8-3889a09f4a2c
│ └── ...
└── Processed
│ ├── train
│ ├── val
│ └── test
Note 1: it will take several hours (training data: ~10 hours; validation data: ~40 mins; and test data: ~40 mins) to preprocess the data.
python3 ba_train.py --root path/to/raw_Argoverse_II
Note 2: during training, the checkpoints will be saved in models/results
automatically.
Note 3: If you don't have sufficient computing resource for training, you can adjust some hyperparameters, e.g., reducing the actor2map distance or map2actor distance. Another trick is to comment out the M2M or B2M layers since they consume too much memory.
Two scripts (ga_distr_train.py
and ba_distr_train.py
) are provided for distributed training. Simply running the following command in your terminal and it will automatically detect the number of GPUs you are going to use:
python3 ga_distr_train.py --root path/to/raw_Argoverse_II
python3 ba_distr_train.py --root path/to/raw_Argoverse_II
During training, it will perform validation steps in several epoches. You can adjust validation frequencies by change the snippets.
The submission script is used for Single-Agent Prediction. You may change the path_to_processed_test_dataset and the checkpoint you want to use.
python3 submission.py
Name | minFDE (K=6) | minFDE (K=1) | minADE (K=6) | minADE (K=1) | MR (K=6) | MR (K=1) | brier-minFDE (K=6) |
---|---|---|---|---|---|---|---|
SGPred | 1.31 | 4.10 | 0.70 | 1.63 | 0.17 | 0.57 | 1.92 |
Note 4: Without resembling, ranking #6.
If you want to submit results to Multi-World Prediction, make some changes to lines to include prediction results for focal agents.
Name | avgMinFDE (K=6) | avgMinFDE (K=1) | avgMinADE (K=6) | avgMinADE (K=1) | actorMR (K=6) | actorCR (K=6) | avgBrierMinFDE (K=6) |
---|---|---|---|---|---|---|---|
SGPred | 1.57 | 2.77 | 0.70 | 1.10 | 0.22 | 0.02 | 2.23 |