A unified framework for autonomous driving dataset management for end-to-end model development
Project description
StandardE2E provides a consistent interface for preprocessing, loading, and training with multimodal data from various end-to-end autonomous driving datasets. It standardizes the complex process of working with different dataset formats, allowing researchers to focus on model development rather than data engineering.
๐ Documentation
- Latest docs: https://standarde2e.readthedocs.io/en/latest/
๐ฆ Installation
Option 1: From PyPI (Recommended for Users)
pip install standard-e2e
Option 2: Development with uv (recommended)
# Install uv: https://docs.astral.sh/uv/
git clone https://github.com/stepankonev/StandardE2E.git
cd StandardE2E
uv sync --all-extras # installs deps and dev deps from uv.lock
uv run pytest tests/ # run tests
Option 3: Manual development (pip/conda)
conda create -n standard_e2e python=3.12
conda activate standard_e2e
pip install -e ".[dev]"
Plan for E2E Autonomous Driving Datasets Support
| Dataset | Cameras | Lidar | HD Map | Detections | Driving Command | Preference Trajectories |
|---|---|---|---|---|---|---|
| Waymo End-to-end |
โ | โ | โ | โ | โ | |
| Waymo Perception |
โ | โ | โ | โ | โ | |
| Navsim |
โ | โ | โ | โ | โ | |
| WayveScenes101 |
โ | โ | โ | โ | โ | |
| Argoverse 2 Sensor |
โ | โ | โ | โ | โ | |
| Argoverse 2 Lidar |
โ | โ | โ | โ | โ | โ |
| Argoverse 2 Map Change |
โ | โ | โ | โ | โ | โ |
| KITTI |
โ | โ | โ | โ | โ | |
| KITTI-360 |
โ | โ | โ | โ | โ | |
| Waymo Motion Prediction |
โ | โ | โ | โ | โ | โ |
| Argoverse 2 Motion Forecasting [?] |
โ | โ | โ | โ | โ | โ |
๐ Key Features
- Unified Dataset Interface: Work with multiple datasets through a single API
- Multimodal Support: Cameras, LiDAR
, HD maps
, trajectories, detections and more
- Flexible Preprocessing: Configurable pipelines with standardization and augmentation
- Trajectory Management: Advanced handling of time-series vehicle data
- PyTorch Integration: Ready-to-use datasets and dataloaders
๐ Quick Start & Examples
Notebooks
- intro_tutorial.ipynb - Introduction to StandardE2E framework
- containers.ipynb - Working with data containers
- multi_dataset_training_and_filtering.ipynb - Multi-dataset training and filtering
- creating_custom_adapter.ipynb - Creating custom dataset adapters
Code Examples
Run from the project root so uv run uses the project environment. If you use pip/conda instead, activate your env and use python in place of uv run python.
-
Preprocess Waymo End-to-end dataset - Convert raw dataset to standardized format (
dataset_preprocessing.py)uv run python examples/dataset_preprocessing.py \ --e2e_dataset_path E2E_DATASET_PATH \ --split {training,val,test} \ --processed_data_path PROCESSED_DATA_PATH
-
Train your model - End-to-end training with multimodal data (
very_simple_training.py). This example illustrates iteration over the preprocessed dataset. Also, in this example for validation we use 2 DataLoaders - full validation split and filtered validation split that only contains samples with preferred trajectories.uv run python examples/very_simple_training.py --processed_data_path PROCESSED_DATA_PATH
-
Create a unified DataLoader: This example shows how to process 2 different datasets within same DataLoader. First, please do preprocessing for
Waymo E2EandWaymo Perceptiondatasets in order to utilize them in the DataLoader with the script (prepare_datasets_waymo_e2e_perception.sh).The script
creating_unified_dataloader.pycreated a unified dataloader that iterates over bothWaymo E2EandWaymo Perceptionin one epoch providing consistent data structure.uv run python examples/creating_unified_dataloader.py --processed_data_path PROCESSED_DATA_PATH
-
Add a new dataset adapter - Guide for adding support for new datasets (
adding_new_dataset.md)
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Citation
If you find this project useful, you can support it by giving it a โญ, or by contributing with your PRs / issues / feature requests. Also, if you use this project, you can greatly support it by citing
@software{standarde2e,
title={StandardE2E: A Unified Framework for Autonomous Driving Dataset Management},
author={stepankonev},
year={2025},
url={https://github.com/stepankonev/StandardE2E}
}
Markdown
[](https://github.com/stepankonev/StandardE2E)
HTML
<a href="https://github.com/stepankonev/StandardE2E">
<img src="https://raw.githubusercontent.com/stepankonev/StandardE2E/refs/heads/main/assets/StandardE2E_gh_badge_dark.svg" alt="StandardE2E"/>
</a>
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file standard_e2e-0.0.3.tar.gz.
File metadata
- Download URL: standard_e2e-0.0.3.tar.gz
- Upload date:
- Size: 84.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
07375be83149b93b0774fb43e8fc910d801f6c940157ca110f9f18c83cc472dd
|
|
| MD5 |
4d431789e7f50a870bc107d10085dec8
|
|
| BLAKE2b-256 |
f755e77da67c3a01015fb4eadb777f8a5d841dfcad3fd67ca3cae0383c8965e9
|
File details
Details for the file standard_e2e-0.0.3-py3-none-any.whl.
File metadata
- Download URL: standard_e2e-0.0.3-py3-none-any.whl
- Upload date:
- Size: 102.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1f915078f924d7a8609fc1a36cddafa2746c7630b78ec04485c3405251edc5e1
|
|
| MD5 |
4d4c86638a5ff264da4c4118b13cff51
|
|
| BLAKE2b-256 |
262abb8777e1a0894f76a1405fd9d339050262cb144b4c32c1d06bbb88e85eee
|