Skip to main content

utilities and pytorch datasets for the KITTI Vision Benchmark Suite

Project description

Pytorch KITTI

code style Python version PyPI version License

This project aims to provide a simple yet effective way to scaffold and load the KITTI Vision Banchmark Dataset providing

  • Datasets: Pytorch datasets to load each dataset

  • Scaffolding: to download the datasets

  • Metrics: common metrics used for each dataset

  • Transformations: utilities to manipulate samples

Installation

To install torch-kitti

$ pip install torch-kitti

Scaffolding datasets

To manually download the datasets the torch-kitti command line utility comes in handy:

$ torch_kitti download --help
usage: Torch Kitti download [-h]
                            {sync_rectified,depth_completion,depth_prediction}
                            path

positional arguments:
  {sync_rectified,depth_completion,depth_prediction}
                        name of the dataset to download
  path                  where scaffold the dataset

optional arguments:
  -h, --help            show this help message and exit

Actually available datasets are:

  • KITTI Depth Completion Dataset
  • KITTI Depth Prediction Dataset
  • KITTI Raw Sync+Rect Dataset

Loading Datasets

All datasets return dictionaries, utilities to manipulate them can be found in the torch_kitti.transforms module. Often each dataset provides options to include optional fields, for instance KittiDepthCompletionDataset usually provides simply the img, its sparse depth groundtruth gt and the sparse lidar hints lidar but using load_stereo=True stereo images will be included for each example.

from torchvision.transforms import Compose, RandomCrop, ToTensor

from torch_kitti.depth_completion import KittiDepthCompletionDataset
from torch_kitti.transforms import ApplyToFeatures

transform = ApplyToFeatures(
    Compose(
        [
            ToTensor(),
            RandomCrop([256, 512]),
        ]
    ),
    features=["img", "gt", "lidar"],
)

ds = KittiDepthCompletionDataset(
    "kitti_raw_sync_rect_root",
    "kitti_depth_completion_root",
    load_stereo=False,
    load_sequence=3,
    transform=transform,
    download=True,  # download if not found
)

Customizing Datasets

Each dataset exposes the elems attribute, containing the paths used by each example loaded, and it can be modified to customize the loaded data, it is composed by DataGroups each containing many DataElems. These latter can load many different file types and each loader automatically will load them if added to each DataGroup, the supported data types are image, depth, pcd, calib, imu, rt and intrinsics.

For example to load only a specific drive sequence for depth completion you could:

class SeqKittiDepthCompletionDataset(KittiDepthCompletionDataset):
    def __init__(self, drive_name: str, *args, **kwargs):
        super().__init__(*args, subset="all", **kwargs)
        self.elems = sorted(
            filter(lambda group: group.drive == drive_name and group.cam == 2, self.elems),
            key=lambda group: group.idx
        )

Contributing

Developing setup

Download from kitti and cd in the folder then prepare a virtual environment (1), install dev and doc dependencies (2) and pre-commit (3).

$ git clone https://github.com/andreaconti/torch_kitti.git
$ cd torch_kitti
$ python3 -m virtualenv .venv && source .venv/bin/activate  # (1)
$ pip install .[dev, doc] # (2)
$ pre-commit install  # (3)
$ python3 setup.py develop
$ pytest

Feel free to open an issue on GitHub, fork the repository and submit a pull request to solve bugs, improve docs, add datasets and features. All new feature must be tested.

Disclaimer on KITTI Vision Benchmark Suite

This library is an utility that downloads and prepares the dataset. The KITTI Vision Benchmark Suite is not hosted by this project nor it's claimed that you have license to use the dataset, it is your responsibility to determine whether you have permission to use this dataset under its license. You can find more details here.

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

torch-kitti-1.0.1.tar.gz (23.2 kB view details)

Uploaded Source

Built Distribution

torch_kitti-1.0.1-py3-none-any.whl (29.6 kB view details)

Uploaded Python 3

File details

Details for the file torch-kitti-1.0.1.tar.gz.

File metadata

  • Download URL: torch-kitti-1.0.1.tar.gz
  • Upload date:
  • Size: 23.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.7

File hashes

Hashes for torch-kitti-1.0.1.tar.gz
Algorithm Hash digest
SHA256 1bab065cb8e4c7fb65ae62c0ee6b64e10dd50ffa27c4c70322dea170dc4b3fa3
MD5 bd94cb99afeba9d09c30d383ea297912
BLAKE2b-256 17bda4cb8ae6cc8d43d206e2d21836ce8edbe0082305ad73856cfbdbae0eb3cf

See more details on using hashes here.

File details

Details for the file torch_kitti-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: torch_kitti-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 29.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.7

File hashes

Hashes for torch_kitti-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 36af1b367a085cd6f8599313461265a33a2b12908ae5e93d74f28ec3acd96d52
MD5 6d14bcff796f57c3d2003ae8c5d010f1
BLAKE2b-256 a331c3c897fda536bf33472ac38902cb8ee0383c001b4890a876f638b568d4bc

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