Think Twice before Driving: Towards Scalable Decoders for End-to-End Autonomous Driving
July 2, 2025 ยท View on GitHub
Important
๐ Stay up to date at opendrivelab.com!
Think Twice before Driving: Towards Scalable Decoders for End-to-End Autonomous Driving
- A SOTA Decoder for End-to-End Autonomous Driving under BEV
- arXiv Paper (CVPR 2023)
Demo Video
Getting Started
- Installation
- Closed-Loop Evaluation in Carla
- Prepare Dataset
- Train Your Own Model
- Calibrations for Different Camera Settings (Optional)
Quick Run in Carla
Install the environment as in Installation, download our checkpoint (GoogleDrive or BaiduYun(ๆๅ็ m5di).) (189K frames training set), put it into open_loop_training/ckpt, and run:
## In the ThinkTwice/ directory
CUDA_VISIBLE_DEVICES=0 nohup bash ./leaderboard/scripts/evaluation_town05long.sh 22023 22033 thinktwice_agent False True open_loop_training/ckpt/thinktwice.pth+open_loop_training/configs/thinktwice.py all_towns_traffic_scenarios_no256 thinktwice_town05long 2>&1 > thinktwice_town05long.log &
Check closed_loop_eval_log/eval_log to see how our model drives in Carla! :oncoming_automobile:
(In case you have a screen to see the interface of Carla simulator, you could remove DISPLAY= in leaderboard/leaderboard/leaderboard_evaluator.py and then you could directly watch with Carla.)
Code Structure
We give the structure of our code. Note that we only introduce those folders/files are commonly used and modified.
ThinkTwice/
โโโ agents # From Carla official
โโโ camera_calibration # When you want to use cameras with different FOV
โโโ closed_loop_eval_log # Save eval logs
โโโ collect_data_json # Save data collection logs
โโโ dataset # Data and metadata for training
โโโ leaderboard # Code for Closed-Loop Evaluation
โ โโโ data # Save routes and scenarios
โ โโโ scripts # Run with Carla
โ โโโ team_code # Your
| | โโโ roach_ap_agent_data_collection.py # Data collection
โ | โโโ thinktwice_agent.py # Interface for closed-loop evaluation of our model
โ โโโ leaderboard # From Carla official
| | โโโ leaderboard_evaluator.py # Entrance of closed-loop evaluation
โโโ roach # Roach for data collection
โโโ scenario_runner # From Carla official
โโโ open_loop_training # Training and Neural Network
| โโโ ckpt # Checkpoints
| โโโ work_dirs # Training Log
| โโโ code # Preprocessing, DataLoader, Model
| โ โโโ apis # Training pipeline for mmdet3D
| โ โโโ core # The hooks for mmdet3D
| โ โโโ datasets # Preprocessing and DataLoader
| | | โโโ pipelines # Functions of Preprocessing and DataLoader
| โ | โโโ samplers # For DDP
| โ | โโโ carla_dataset.py # Framework of Preprocessing and DataLoading
| โ โโโ model_code # Neural Network
| | | โโโ backbones # Module of Encoder
| | | โโโ dense_heads # Module of Decoder and Loss Functions
| โ โโโ encoder_decoder_framework.py # Entrance of Neural Network
| โโโ train.py # Entrance of Training
License
All assets and code are under the Apache 2.0 license unless specified otherwise.
Bibtex
If this work is helpful for your research, please consider citing the following BibTeX entry.
@inproceedings{jia2023thinktwice,
title={Think Twice before Driving: Towards Scalable Decoders for End-to-End Autonomous Driving},
author={Jia, Xiaosong and Wu, Penghao and Chen, Li and Xie, Jiangwei and He, Conghui and Yan, Junchi and Li, Hongyang},
booktitle={CVPR},
year={2023}
}
Related Resources
Many thanks to the open-source community!
- End-to-end Autonomous Driving Survey (:rocket:Ours!)
- TCP (:rocket:Ours!)
- BEVFormer (:rocket:Ours!)
- UniAD (:rocket:Ours!)
- ST-P3 (:rocket:Ours!)
- Carla
- Roach
- Transfuser
- CARLA_GARGE
- LAV
- IBISCape
