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]"

C++ acceleration backend (optional)

Installing baglab_cpp_backend enables near I/O-bound rosbag loading via rosbag2_cpp. Requires a sourced ROS2 environment.

source /opt/ros/humble/setup.bash  # or jazzy

# Option 1: pip install
cd baglab
pip install scikit-build-core pybind11 numpy
pip install --no-build-isolation ./baglab_cpp_backend

# Option 2: colcon build
colcon build --packages-select baglab_cpp_backend
source install/setup.bash

Check whether the backend is available:

import baglab
print(baglab.has_cpp_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-0.2.0.tar.gz (45.3 kB view details)

Uploaded Source

Built Distribution

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

baglab-0.2.0-py3-none-any.whl (41.5 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for baglab-0.2.0.tar.gz
Algorithm Hash digest
SHA256 57a0a1eef64d4eb25bc6b56389205c1f0b431a70d78b461c3c21504791007a0f
MD5 32a69e6508fb27bfa90b9fe56e284404
BLAKE2b-256 455df843aa3045a27249c8f07f866dfdf858809d008a8c05ff701ea85e721a53

See more details on using hashes here.

Provenance

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

File metadata

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

File hashes

Hashes for baglab-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 bd83e28b12eb6eb15bbee64b727c753363ddba6fdf908e762749a62b2648e2ed
MD5 1ba2ab15ab846ca055c9e3c69b720b52
BLAKE2b-256 2dc5133ed5843b80f7fdcbf2e1bf40988340ec5d613345d666602569bbc3a6b8

See more details on using hashes here.

Provenance

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