Welcome to pointcloudset’s documentation!¶
Features¶
Handles point clouds over time
Building complex pipelines with a clean and maintainable code
newpointcloud = pointcloud.limit("x",-5,5).filter("quantile","reflectivity", ">",0.5)
Apply arbitrary functions to datasets of point clouds
def isolate_target(frame: PointCloud) -> PointCloud:
return frame.limit("x",0,1).limit("y",0,1)
def diff_to_pointcloud(pointcloud: PointCloud, to_compare: PointCloud) -> PointCloud:
return pointcloud.diff("pointcloud", to_compare)
result = dataset.apply(isolate_target).apply(diff_to_pointcloud, to_compare=dataset[0])
Includes powerful aggregation method agg similar to pandas
dataset.agg(["min","max","mean","std"])
Support for large files with lazy evaluation and parallel processing
data:image/s3,"s3://crabby-images/5f92f/5f92fa864ba85251e4df0d9e476e45380ee3493d" alt="https://raw.githubusercontent.com/virtual-vehicle/pointcloudset/master/images/dask.gif"
Support for numerical data per point (intensity, range, noise …)
Interactive 3D visualisation
data:image/s3,"s3://crabby-images/ca3c3/ca3c302f7e01fc3dadc79833a5c6d533ffd306be" alt="https://raw.githubusercontent.com/virtual-vehicle/pointcloudset/master/images/tree.gif"
High level processing based on dask, pandas, open3D and pyntcloud
Docker image is available
Optimised - but not limited to - automotive lidar
Directly read ROS files and many pointcloud file formats
A command line tool to convert ROS 1 & 2 files
Use case examples¶
Post processing and analytics of a lidar dataset recorded by ROS
A collection of multiple lidar scans from a terrestrial laser scanner
Comparison of multiple point clouds to a ground truth
Analytics of point clouds over time
Developing algorithms on a single frame and then applying them to huge datasets
Installation with Docker¶
The easiest way to get started is to use the pre-build docker tgoelles/pointcloudset.
Quickstart¶
from pointcloudset import Dataset, PointCloud
from pathlib import Path
import urllib.request
urllib.request.urlretrieve("https://github.com/virtual-vehicle/pointcloudset/raw/master/tests/testdata/test.bag", "test.bag")
urllib.request.urlretrieve("https://github.com/virtual-vehicle/pointcloudset/raw/master/tests/testdata/las_files/test_tree.las", "test_tree.las")
dataset = Dataset.from_file(Path("test.bag"), topic="/os1_cloud_node/points", keep_zeros=False)
pointcloud = dataset[1]
tree = PointCloud.from_file(Path("test_tree.las"))
tree.plot("x", hover_data=True)
This produces the plot from the animation above.
Read the html documentation.
Have a look at the tutorial notebooks in the documentation folder
For even more usage examples you can have a look at the tests
CLI to convert ROS1 and ROS2 files: pointcloudset convert¶
The package includes a powerful CLI to convert pointclouds in ROS1 & 2 files into many formats like pointcloudset, csv, las and many more. It is capable of handling both mcap and db3 ROS files.
pointcloudset convert --output-format csv --output-dir converted_csv test.bag
data:image/s3,"s3://crabby-images/de84c/de84ce5154cf7ac65c7b2f08e8f552ecca31c195" alt="https://raw.githubusercontent.com/virtual-vehicle/pointcloudset/master/images/cli_demo.gif"
You can view PointCloud2 messages with
pointcloudset topics test.bag
Citation and contact¶
Thomas Gölles
email: thomas.goelles@v2c2.at
Please cite our JOSS paper if you use pointcloudset.
@article{Goelles2021,
doi = {10.21105/joss.03471},
url = {https://doi.org/10.21105/joss.03471},
year = {2021},
publisher = {The Open Journal},
volume = {6},
number = {65},
pages = {3471},
author = {Thomas Goelles and Birgit Schlager and Stefan Muckenhuber and Sarah Haas and Tobias Hammer},
title = {`pointcloudset`: Efficient Analysis of Large Datasets of Point Clouds Recorded Over Time},
journal = {Journal of Open Source Software}
}
Tutorial
Convert ROS 1 and ROS 2 files
Contribute
Python API
- How to read the API documentation
- pointcloudset package
- pointcloudset.diff package
- pointcloudset.filter package
- pointcloudset.geometry package
- pointcloudset.io package
- pointcloudset.pipeline package
- pointcloudset.plot package
- pointcloudset.dataset module
- pointcloudset.dataset_core module
- pointcloudset.pointcloud module
- pointcloudset.pointcloud_core module
Changelog
- Changelog
- 0.10.0 - (2024-12-03)
- 0.9.0 - (2023-03-30)
- 0.8.1 - (2023-03-23)
- 0.8.0 - (2022-11-13)
- 0.7.0 - (2022-09-27)
- 0.6.3 - (2022-06-08)
- 0.6.2 - (2022-06-03)
- 0.6.1 - (2022-06-03)
- 0.6.0 - (2022-06-03)
- 0.5.1 - (2022-05-30)
- 0.5.0 - (2022-05-30)
- 0.4.3 - (2022-05-10)
- 0.4.2 - (2022-05-10)
- 0.4.1 - (2022-02-22)
- 0.4.0 - (2022-02-22)
- 0.3.4 - (2022-02-18)
- 0.3.3 - (2021-09-27)
- 0.3.2 - (2021-08-18)
- 0.3.1 - (2021-08-17)
- 0.3.0 (2021-08-17)
- 0.2.3 (2021-07-12)