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.0.0.tar.gz (47.2 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.0.0-py3-none-any.whl (42.7 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for baglab-1.0.0.tar.gz
Algorithm Hash digest
SHA256 f55161a96059117261c2061579543e5eb748d7b90709c4ee36797fdf9ad160d7
MD5 f79a61419b33b970012da599915e960f
BLAKE2b-256 3e1cb3b37dbcdacd9d9ed256dc55cb1dbfe7d42e374c2b4cf24efbe4b491e7b4

See more details on using hashes here.

Provenance

The following attestation bundles were made for baglab-1.0.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.0.0-py3-none-any.whl.

File metadata

  • Download URL: baglab-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 42.7 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.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c54bfb95472cf3557b52a9a9b26c74fd155f5be55985ab05ad6cfc25bdc58f3d
MD5 637a80b5f914cd7a8e8f0c038a2c29e0
BLAKE2b-256 6f4ed291e6b76efdc8e854d5b99cc228eb627bb027f8fc9fe67895b8ddb33630

See more details on using hashes here.

Provenance

The following attestation bundles were made for baglab-1.0.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