# metadrive **Repository Path**: codemaxi/metadrive ## Basic Information - **Project Name**: metadrive - **Description**: No description available - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2024-07-09 - **Last Updated**: 2024-07-09 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README
![](documentation/source/figs/logo-horizon.png)
# MetaDrive: an Open-source Driving Simulator for AI and Autonomy Research [![build](https://github.com/metadriverse/metadrive/workflows/test/badge.svg)](http://github.com/metadriverse/metadrive/actions) [![Documentation](https://readthedocs.org/projects/metadrive-simulator/badge/?version=latest)](https://metadrive-simulator.readthedocs.io) [![GitHub license](https://img.shields.io/github/license/metadriverse/metadrive)](https://github.com/metadriverse/metadrive/blob/main/LICENSE.txt) [![GitHub contributors](https://img.shields.io/github/contributors/metadriverse/metadrive)](https://github.com/metadriverse/metadrive/graphs/contributors) [![Downloads](https://static.pepy.tech/badge/MetaDrive-simulator)](https://pepy.tech/project/MetaDrive-simulator)
[ Documentation | Colab Examples | Demo Video | Website | Paper | Relevant Projects ]

MetaDrive is a driving simulator with the following key features: - **Compositional**: It supports generating infinite scenes with various road maps and traffic settings for the research of generalizable RL. - **Lightweight**: It is easy to install and run. It can run up to +1000 FPS on a standard PC. - **Realistic**: Accurate physics simulation and multiple sensory input including Lidar, RGB images, top-down semantic map and first-person view images. ## πŸ›  Quick Start Install MetaDrive via: ```bash git clone https://github.com/metadriverse/metadrive.git cd metadrive pip install -e . ``` or ```bash pip install metadrive-simulator ``` *Note that the program is tested on both Linux and Windows. Some control and display issues in MacOS wait to be solved* You can verify the installation of MetaDrive via running the testing script: ```bash # Go to a folder where no sub-folder calls metadrive python -m metadrive.examples.profile_metadrive ``` *Note that please do not run the above command in a folder that has a sub-folder called `./metadrive`.* ## πŸš• Examples We provide [examples](https://github.com/metadriverse/metadrive/tree/main/metadrive/examples) to demonstrate features and basic usages of MetaDrive after the local installation. There is an `.ipynb` example which can be directly opened in Colab. [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/metadriverse/metadrive/blob/main/metadrive/examples/Basic_MetaDrive_Usages.ipynb) Also, you can try examples in the documentation directly in Colab! See more details in [Documentations](#-documentations). ### Single Agent Environment Run the following command to launch a simple driving scenario with auto-drive mode on. Press W, A, S, D to drive the vehicle manually. ```bash python -m metadrive.examples.drive_in_single_agent_env ``` Run the following command to launch a safe driving scenario, which includes more complex obstacles and cost to be yielded. ```bash python -m metadrive.examples.drive_in_safe_metadrive_env ``` ### Multi-Agent Environment You can also launch an instance of Multi-Agent scenario as follows ```bash python -m metadrive.examples.drive_in_multi_agent_env --env roundabout ``` ```--env``` accepts following parmeters: `roundabout` (default), `intersection`, `tollgate`, `bottleneck`, `parkinglot`, `pgmap`. Adding ```--top_down``` can launch top-down pygame renderer. ### Real Environment Running the following script enables driving in a scenario constructed from nuScenes dataset or Waymo dataset. ```bash python -m metadrive.examples.drive_in_real_env ``` The default real-world dataset is nuScenes. Use ```--waymo``` to visualize Waymo scenarios. Traffic vehicles can not response to surrounding vchicles if directly replaying them. Add argument ```--reactive_traffic``` to use an IDM policy control them and make them reactive. Press key ```r``` for loading a new scenario, and ```b``` or ```q``` for switching perspective. [comment]: <> (### LQY: avoid introducing these trivial things ) [comment]: <> (Run the example of procedural generation of a new map as:) [comment]: <> (```bash) [comment]: <> (python -m metadrive.examples.procedural_generation) [comment]: <> (```) [comment]: <> (*Note that the scripts above can not be run in a headless machine.*) [comment]: <> (*Please refer to the installation guideline in documentation for more information about how to launch runing in a headless machine.*) [comment]: <> (Run the following command to draw the generated maps from procedural generation:) [comment]: <> (```bash) [comment]: <> (python -m metadrive.examples.draw_maps) [comment]: <> (```) ### Basic Usage To build the RL environment in python script, you can simply code in the Farama Gymnasium format as: ```python from metadrive.envs.metadrive_env import MetaDriveEnv env = MetaDriveEnv(config={"use_render": True}) obs, info = env.reset() for i in range(1000): obs, reward, terminated, truncated, info = env.step(env.action_space.sample()) if terminated or truncated: env.reset() env.close() ``` ## 🏫 Documentations Please find more details in: https://metadrive-simulator.readthedocs.io ### Running Examples in Doc The documentation is built with `.ipynb` so every example can run locally or with colab. For Colab running, on the Colab interface, click β€œGitHub,” enter the URL of MetaDrive: https://github.com/metadriverse/metadrive, and hit the search icon. After running examples, you are expected to get the same output and visualization results as the documentation! For example, hitting the following icon opens the source `.ipynb` file of the documentation section: [Environments](https://metadrive-simulator.readthedocs.io/en/latest/rl_environments.html). [![Open In Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/metadriverse/metadrive/blob/main/documentation/source/rl_environments.ipynb) ## πŸ“Ž References If you use MetaDrive in your own work, please cite: ```latex @article{li2022metadrive, title={Metadrive: Composing diverse driving scenarios for generalizable reinforcement learning}, author={Li, Quanyi and Peng, Zhenghao and Feng, Lan and Zhang, Qihang and Xue, Zhenghai and Zhou, Bolei}, journal={IEEE Transactions on Pattern Analysis and Machine Intelligence}, year={2022} } ``` ## πŸŽ‰ Relevant Projects **Learning to Simulate Self-driven Particles System with Coordinated Policy Optimization** \ Zhenghao Peng, Quanyi Li, Chunxiao Liu, Bolei Zhou \ *NeurIPS 2021* \ [Paper] [Code] [Webpage] [Poster] [Talk] [Results&Models] **Safe Driving via Expert Guided Policy Optimization** \ Zhenghao Peng*, Quanyi Li*, Chunxiao Liu, Bolei Zhou \ *Conference on Robot Learning (CoRL) 2021* \ [Paper] [Code] [Webpage] [Poster] **Efficient Learning of Safe Driving Policy via Human-AI Copilot Optimization** \ Quanyi Li*, Zhenghao Peng*, Bolei Zhou \ *ICLR 2022* \ [Paper] [Code] [Webpage] [Poster] [Talk] **Human-AI Shared Control via Policy Dissection** \ Quanyi Li, Zhenghao Peng, Haibin Wu, Lan Feng, Bolei Zhou \ *NeurIPS 2022* \ [Paper] [Code] [Webpage] And more: * Yang, Yujie, Yuxuan Jiang, Yichen Liu, Jianyu Chen, and Shengbo Eben Li. "Model-Free Safe Reinforcement Learning through Neural Barrier Certificate." IEEE Robotics and Automation Letters (2023). * Feng, Lan, Quanyi Li, Zhenghao Peng, Shuhan Tan, and Bolei Zhou. "TrafficGen: Learning to Generate Diverse and Realistic Traffic Scenarios." (**ICRA 2023**) * Zhenghai Xue, Zhenghao Peng, Quanyi Li, Zhihan Liu, Bolei Zhou. "Guarded Policy Optimization with Imperfect Online Demonstrations." (**ICLR 2023**) ## Acknowledgement The simulator can not be built without the help from Panda3D community and the following open-sourced projects: - panda3d-simplepbr: https://github.com/Moguri/panda3d-simplepbr - panda3d-gltf: https://github.com/Moguri/panda3d-gltf - RenderPipeline (RP): https://github.com/tobspr/RenderPipeline - Water effect for RP: https://github.com/kergalym/RenderPipeline - procedural_panda3d_model_primitives: https://github.com/Epihaius/procedural_panda3d_model_primitives - DiamondSquare for terrain generation: https://github.com/buckinha/DiamondSquare - KITSUNETSUKI-Asset-Tools: https://github.com/kitsune-ONE-team/KITSUNETSUKI-Asset-Tools