- [2023/3/14]: Code Released.
- [2022/10/6]: SOLOFusion achieves SOTA on Camera-Only nuScenes Detection Task with 54.0% mAP and 61.9% NDS!
- [2022/10/5]: Paper released on arXiv.
While recent camera-only 3D detection methods leverage multiple timesteps, the limited history they use significantly hampers the extent to which temporal fusion can improve object perception. Observing that existing works' fusion of multi-frame images are instances of temporal stereo matching, we find that performance is hindered by the interplay between 1) the low granularity of matching resolution and 2) the sub-optimal multi-view setup produced by limited history usage. Our theoretical and empirical analysis demonstrates that the optimal temporal difference between views varies significantly for different pixels and depths, making it necessary to fuse many timesteps over long-term history. Building on our investigation, we propose to generate a cost volume from a long history of image observations, compensating for the coarse but efficient matching resolution with a more optimal multi-view matching setup. Further, we augment the per-frame monocular depth predictions used for long-term, coarse matching with short-term, fine-grained matching and find that long and short term temporal fusion are highly complementary. While maintaining high efficiency, our framework sets new state-of-the-art on nuScenes, achieving first place on the test set and outperforming previous best art by 5.2% mAP and 3.7% NDS on the validation set.
Please see getting_started.md
By default, all configs are set-up to train with 4 GPUs, 16 samples per gpu. Please reference the configs and change as needed. Models using long-term fusion are trained in 2 phases, similar to NeuralRecon. If # of GPUs or batch size is changed, the resume_from parameter in phase2 configs must be updated. To train R50 backbone without CBGS:
Phase 1:
./tools/dist_train.sh configs/solofusion/r50-fp16_phase1.py 4 --gpus 4 --autoscale-lr --no-validate
Phase 2:
./tools/dist_train.sh configs/solofusion/r50-fp16_phase2.py 4 --gpus 4 --autoscale-lr --no-validate
Note that --autoscale-lr
is important.
Our model must process data samples sequentially. This is done during training via our custom sampler using IterBasedRunner but has not been adapted for inference. Thus, inference must be done on a single-gpu, single-batch size. In addition, due to some issues in MMCV in using EMA with IterBasedRunner, EMA weights must be transferred to main weights before inference.
Run the following commands:
python tools/swap_ema_and_non_ema.py work_dirs/r50-fp16_phase2/iter_10536.pth
./tools/dist_test.sh configs/solofusion/r50-fp16_phase2.py work_dirs/r50-fp16_phase2/iter_10536_ema.pth 1 --eval bbox
Method | mAP | NDS | Model | Log |
---|---|---|---|---|
R50 SOLOFusion Short-Only | 34.4 | 39.1 | Link | Link |
R50 SOLOFusion Long-Only | 38.7 | 48.5 | Link | Link |
R50 SOLOFusion | 40.6 | 49.7 | Link | Link |
R50 SOLOFusion + CBGS | 43.0 | 53.8 | Link | Link |
We thank numerous excellent works and open-source codebases:
If this work is helpful for your research, please consider citing:
@article{Park2022TimeWT,
title={Time Will Tell: New Outlooks and A Baseline for Temporal Multi-View 3D Object Detection},
author={Park, Jinhyung and Xu, Chenfeng and Yang, Shijia and Keutzer, Kurt and Kitani, Kris and Tomizuka, Masayoshi and Zhan, Wei},
booktitle={International Conference on Learning Representations},
year={2023}
}