No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.

omnivision package from omnivision repo

omnivision

Package Summary

Tags No category tags.
Version 0.0.1
License GNU GPL-3.0
Build type AMENT_PYTHON
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/blainektmo/omnivision.git
VCS Type git
VCS Version main
Last Updated 2025-02-25
Dev Status UNMAINTAINED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

A ros 2 package designed for 360° camera and lidar fusion. It captures equirectangular video feeds and lidar point clouds, fusing them to create textured 3d representations of the environment.

Additional Links

No additional links.

Maintainers

  • blaine

Authors

No additional authors.

Omnivision 🌐📸

A ros 2 package designed for 360° camera and lidar fusion. it captures equirectangular video feeds and lidar point clouds, fusing them to create textured 3d representations of the environment. omnivision provides visualization feeds and 360° depth information with only 2 sensors.

Applications include anywhere you need full surrounding depth information using only 2 sensors. This idea was originally created for full coverage lane detection, but would love to see other use cases!

This project was created for WayneHacks 3 @ Wayne State University! See the DevPost submission here.

Examples

Image Overlay

MovingAround

Texturized Pointcloud

TexturizedPointcloud

Using depth information for plotting lanes

lanes

Features 🚀

  • 360° Camera and LiDAR Integration: Full environmental coverage from 3D LiDAR and 360° camera.

  • Data Fusion: Combine camera and LiDAR data to generate textured point clouds.

  • Depth Map Generation: Creates textured and grayscale depth maps.

  • Dynamic Visualization Compute: Only generates pointclouds / depthmaps when topics have subscribers.

Installation 🛠️

Prerequisites:w

  • ROS 2 (Humble or newer recommended)

  • Python 3.8+

  • OpenCV

  • PCL

  • NumPy

Steps

  • Clone the repository into your ROS 2 workspace:
git clone git@github.com:BlaineKTMO/omnivision.git /path/to/ros2_ws/src/omnivision

Install dependencies:


sudo apt install ros-<your_ros2_distro>-cv-bridge ros-<your_ros2_distro>-pcl-ros
pip install numpy opencv-python

Build the package:

cd /path/to/ros2_ws
colcon build --symlink-install

Source the workspace:

source /path/to/ros2_ws/install/setup.bash

Usage 🖥️

Launching the Package

To start the Omnivision system, use the provided launch file:

ros2 launch omnivision bringup.launch.py

Parameters

Customize the launch file with the following parameters:

  • camera_topic: Topic name for the 360-degree camera feed (default: /camera/image_raw).

  • lidar_topic: Topic name for the LiDAR point cloud data (default: /lidar/points).

  • output_topic: Topic name for the fused textured point cloud (default: /omnivision/fused_cloud).

  • depth_map_topic: Topic name for the generated depth map (default: /omnivision/depth_map).

Example

To launch with custom topics:

ros2 launch omnivision bringup.launch.py camera_topic:=/my_camera lidar_topic:=/my_lidar

To Do (Contributions Welcome!) 🛠️

  • Optimization: Improve processing efficiency and reduce resource usage.

  • LiDAR Interpolation: Add an option to interpolate LiDAR data for denser point clouds.

  • Launch File Configuration: Expand the launch file to support more customization options.

  • Documentation: Add additional details for usage or debugging.

  • Testing: Add unit tests.

  • Automatic localization: Capture camera transformation automatically.

Contributing 🤝

This is a great project for new ROS2 developers to contribute to. Please create an issue prior to pull requesting to foster collaboration.

License 📜

This project is licensed under the GNU GPL-3.0 License. See the LICENSE file for details.

Contact 📧

For questions, suggestions, or collaboration opportunities, please open an issue on the repository or contact the maintainers directly.

CHANGELOG
No CHANGELOG found.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Package Dependencies

System Dependencies

Dependant Packages

No known dependants.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged omnivision at Robotics Stack Exchange

No version for distro noetic. Known supported distros are highlighted in the buttons above.
No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro lunar. Known supported distros are highlighted in the buttons above.
No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.
No version for distro kinetic. Known supported distros are highlighted in the buttons above.
No version for distro melodic. Known supported distros are highlighted in the buttons above.