Skip to main content

ROS2 rosbag data analysis library

Project description

baglab

ROS2 rosbag data analysis library. Load, explore, and visualize rosbag data with MATLAB-like simplicity using pandas DataFrames.

Features

  • Lazy loading — open a bag and read only the topics you need
  • Dot-access — navigate message fields like msg.twist.linear.x
  • Geometry — quaternion/euler conversion, distance, pose interpolation
  • Signal processing — lowpass filter, FFT, differentiation, integration
  • Diagnostics — topic rate, message gaps, latency chain analysis
  • Plotting — time-series, trajectory, step response, error band

Installation

Prerequisites

  • Python 3.10+
  • ROS2 (Humble / Jazzy)

baglab (Python only)

pip install baglab

For development:

git clone https://github.com/Kotakku/baglab.git
cd baglab
pip install -e ".[dev]"

MCAP acceleration backend (optional)

Installing baglab_mcap_backend enables high-speed MCAP reading without ROS 2 dependency.

cd baglab
sudo apt install liblz4-dev libzstd-dev
pip install --no-build-isolation ./baglab_mcap_backend

Check whether the backend is available:

import baglab
print(baglab.has_mcap_backend())  # True / False

baglab works without the backend — it falls back to rosbags (pure Python).

Usage

import baglab

# Load a rosbag (lazy loading)
bag = baglab.load("path/to/rosbag")

# List topics
print(bag.topics)
# {"/motor/angle": "sensor_msgs/msg/JointState", ...}

# Access topic data (loaded on first access)
twist_df = bag["/cmd_vel"]

# Dot-access for message fields
twist_df.msg.twist.linear.x         # Series
twist_df.msg.twist.linear.df        # DataFrame (columns: [x, y, z])

# Timestamps
t = baglab.stamp_to_sec(twist_df)                  # absolute [s]
t = baglab.stamp_to_sec(twist_df, relative=True)   # relative (starts at 0)

# Reindex by publication timestamp
twist_df = baglab.reindex_by_stamp(twist_df)

Plot example

import baglab
import matplotlib.pyplot as plt

bag = baglab.load("path/to/rosbag")
twist_df = bag["/cmd_vel"]

t = baglab.stamp_to_sec(twist_df, relative=True)
vel = twist_df.msg.twist.linear.df

fig, axes = plt.subplots(3, 1, sharex=True)
for ax, axis_name in zip(axes, ["x", "y", "z"]):
    ax.plot(t, vel[axis_name])
    ax.set_ylabel(axis_name)
axes[-1].set_xlabel("time [s]")
plt.show()

Documentation

https://kotakku.github.io/baglab/

License

Apache-2.0

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

baglab-1.1.0.tar.gz (49.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

baglab-1.1.0-py3-none-any.whl (45.3 kB view details)

Uploaded Python 3

File details

Details for the file baglab-1.1.0.tar.gz.

File metadata

  • Download URL: baglab-1.1.0.tar.gz
  • Upload date:
  • Size: 49.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for baglab-1.1.0.tar.gz
Algorithm Hash digest
SHA256 57b97ffacb3785c70859f8de6602e456b9bc458a90876fbbc75739b21d62ffdd
MD5 c024d0c1852c9890dba6eacbaf24df14
BLAKE2b-256 a50b3b8b8a254314c1103d30b09466adfb1eb9a2bc25c24398d1b4362629ce5d

See more details on using hashes here.

Provenance

The following attestation bundles were made for baglab-1.1.0.tar.gz:

Publisher: publish.yml on Kotakku/baglab

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file baglab-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: baglab-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 45.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for baglab-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6a62332e7c35ca2887eace0f8f1bc22ac90f522c48cbe763601bd71d37cfebf8
MD5 5382ee6fabd6239f6c35a60583e6ced9
BLAKE2b-256 94163ce514d392bfbfb5c90937c23e6c16574699859d4a9d72aaede26c007156

See more details on using hashes here.

Provenance

The following attestation bundles were made for baglab-1.1.0-py3-none-any.whl:

Publisher: publish.yml on Kotakku/baglab

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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