Skip to main content

An Efficient and Scalable Data Collection and Management Framework For Robotics Learning

Project description

🦊 Fog-RT-X

🦊 Fog-RT-X: An Efficient and Scalable Data Collection and Management Framework For Robotics Learning. Support Open-X-Embodiment, 🤗HuggingFace.

🦊 Fog-RT-X considers both speed 🚀 and memory efficiency 📈 with active metadata and lazily-loaded trajectory data. It supports flexible and distributed dataset partitioning. It provides native support to cloud storage.

Design Doc | Dataset Visualization

Install

pip install fog_x

Usage

import fog_x

# 🦊 Dataset Creation 
# from distributed dataset storage 
dataset = fog_x.Dataset(
    name="demo_ds",
    path="~/test_dataset", # can be AWS S3, Google Bucket! 
)  

# 🦊 Data collection: 
# create a new trajectory
episode = dataset.new_episode()
# collect step data for the episode
episode.add(feature = "arm_view", value = "image1.jpg")
# Automatically time-aligns and saves the trajectory
episode.close()

# 🦊 Data Loading:
# load from existing RT-X/Open-X datasets
dataset.load_rtx_episodes(
    name="berkeley_autolab_ur5",
    additional_metadata={"collector": "User 2"}
)

# 🦊 Data Management and Analytics: 
# Compute and memory efficient filter, map, aggregate, groupby
episode_info = dataset.get_episode_info()
desired_episodes = episode_info.filter(episode_info["collector"] == "User 2")

# 🦊 Data Sharing and Usage:
# Export and share the dataset as standard Open-X-Embodiment format
# it also supports hugging face, and more!
dataset.export(desired_episodes, format="rtx")
# Load with pytorch dataloader
torch.utils.data.DataLoader(dataset.as_pytorch_dataset(desired_episodes))

Design

🦊 Fog-RT-X recognizes most post-processing, analytics and management involves the trajectory-level data, such as tags, while actual trajectory steps are rarely read, written and transformed. Acessing and modifying trajectory data is very expensive and hard.

As a result, 🦊 Fog-RT-X proposes

  • a user-friendly metadata table via Pandas Datframe for speed and freedom
  • a LazyFrame from Polars for the trajectory dataset that only loads and transform the data if needed
  • parquet as storage format for distributed storage and columnar support compared to tensorflow records
  • Easy and automatic RT-X/Open-X dataset export and pytorch dataloading

More Coming Soon!

Currently we see a more than 60% space saving on some existing RT-X datasets. This can be even more by re-paritioning the dataset. Our next steps can be found in the planning doc. Feedback welcome through issues or PR to planning doc!

We also note we are at a beta-testing phase. We make our best effort to be backward-compatible but interfaces may be unstable.

Development

Read the CONTRIBUTING.md file.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fog_x-0.1.0b2.tar.gz (60.9 kB view details)

Uploaded Source

Built Distribution

fog_x-0.1.0b2-py3-none-any.whl (30.9 kB view details)

Uploaded Python 3

File details

Details for the file fog_x-0.1.0b2.tar.gz.

File metadata

  • Download URL: fog_x-0.1.0b2.tar.gz
  • Upload date:
  • Size: 60.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.10.4

File hashes

Hashes for fog_x-0.1.0b2.tar.gz
Algorithm Hash digest
SHA256 343b870c78d617a3d4b77faa5f5134ebe1aa24d3fd3e0cf72d92623a88f4289d
MD5 f8375aebc8c26b4484b7fa86d645b305
BLAKE2b-256 674ab288424ecbb87de54fa6c13e02698ec9a371c3e05d4575134ffe5ba46960

See more details on using hashes here.

File details

Details for the file fog_x-0.1.0b2-py3-none-any.whl.

File metadata

  • Download URL: fog_x-0.1.0b2-py3-none-any.whl
  • Upload date:
  • Size: 30.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.10.4

File hashes

Hashes for fog_x-0.1.0b2-py3-none-any.whl
Algorithm Hash digest
SHA256 f0e97e956e1e8655a2f0917c52ec13ea60f2e8a691e5dd390746d80a793d7b28
MD5 3e580ee937ad16df4d521026c7f8eded
BLAKE2b-256 a46cae130f412be8479e17a228caa2b1bba5ad91bd15c11e77c1700e67db4d90

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page