Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/JuanTarrio/rebvo

Realtime Edge Based Visual Odometry for a Monocular Camera
https://github.com/JuanTarrio/rebvo

Last synced: 2 months ago
JSON representation

Realtime Edge Based Visual Odometry for a Monocular Camera

Awesome Lists containing this project

README

        

# REBiVO
## Realtime Edge Based Inertial Visual Odometry for a Monocular Camera

Tarrio, J. J., & Pedre, S. (2015). Realtime Edge-Based Visual Odometry
for a Monocular Camera. In Proceedings of the IEEE International Conference
on Computer Vision (pp. 702-710).

Tarrio, J. J., & Pedre, S. (2017). Realtime edge based visual inertial odometry for MAV teleoperation in indoor environments. Journal of Intelligent and Robotic Systems.

REBiVO tracks a camera in Realtime using edges and inertial data, is a slim system targeted for MAV operation. The system is split in 4 components.
A library containing the core (rebvolib/librebvolib.a)
An on-board app (app/rebvorun) to launch the library to do all the processing and send data over UDP
An an OpenGL visualizer (app/visualizer) to show the newwork transmitted data.
A ROS wrapper (under development)

Introductory video: https://youtu.be/7pn29iGklgI

### System requirements

In ubuntu and most linux dist this libraries can be downloaded directly from the
repos, except for TooN.

-- C++11

-- Linux, X11, v4l2

-- OpenGL development libraries (GL,GLU,glut)

-- TooN 2.2 mathematical library (http://www.edwardrosten.com/cvd/toon.html - ZIP provided in the repo)

-- Lapack (for advanced TooN functions)

-- LibAV (Video Codecs)

-- LibGD (Image managment)

-- Optionally NE10 for ARM Neon optimizations

### Compiling

REBVO has been developed using QT creator, so a project file is provided in the main folder. Also a makefile is provided on the main directory for 64bit machines.

For x86 compile using (on the root directory):

make

For 64bit desktop use:

make REBVOFLAGS=-m64

for ARM:

make REBVOFLAGS='-mtune=cortex-a15 -mfpu=neon'

for ARM using NE10

make REBVOFLAGS='-mtune=cortex-a15 -mfpu=neon -DUSE_NE10 -lNE10'

#### Output

Library: rebvolib/librebvolib.a
Rebvo Launcher: app/rebvorun/rebvorun
Visualizer: app/visualizer/visualizer

### Imu Integration

IMU measurements are integrated trough the ImuGrabber class, that implements a circular buffer, timestamp search utilities and inter-frame integration.

For IMU data in a csv dataset style the ImuGraber supports a file loadding function (Config IMUMode=2).
For a custom IMU, timestamped data can be pushed using REBVO::pushIMU() function.

#### Imu Fusion

IMU fusion is done using a two stage Bayesian filter. Sensor noise covariances should be set for optimal performance.

An initial guess for Giro Bias should be provided for highly biased sensors, an initial automatic guess could be used if the system is started still.

### Camera Drivers

Three classes are provided for camera management:

-- v4lCam is a wrapper to the C functions provided in video_io for interacting with
the v4l2 lib.

-- SimCamera is a simple class designed to load uncompressed video from a file. For compressed video
formats check the Video2SimCam section.

-- DataSetCam is used to load the images from the TUM datasets used to benchmark the
paper (add the dataset directory and image file list to the config file).

-- Custom cam, a class for external loading of images

All three classes inherit from VideoCam class, this class is able to generate the
video files used by simcam.

#### Using the custom camera

If the custom camera is selected, images has to be loaded to the rebvo object. Use the REBVO:requestCustomCamBuffer()
function to request an Image buffer, save your image to that buffer and call REBVO::releaseCustomCamBuffer to release.
This can be done in the aplication thread, images are passed transparently using a pipe circular buffer.

#### Video2SimCam Utility

Currently rebvo canot load compressed video directly (a feature that is gonna be added soon), so
a simple utility is provided in the Video2SimCam folder that uses OpenCV VideoCapture to uncompress
the video in the SimCam format (can take a lot of disk space!).

### Customizing the Output

A callback function can be configured using the library function REBVO::setOutputCallback(). This a callback is called on the third thread with a reference
to a struct containing all the algorithm's output.

The funtion REBVO::getNav() can also bue used to extract navigation parameters

### Ros Support

The folder ros/src/rebvo_ros contains an ROS-indigo wrapper that is under development. 2 launchers and configuration files are provided, one for monocular camera
and the second for trying on the EuRoMav Dataset using ros bag files. The nodelet is algo a good example of how to use the library.

### Configuring the system

A GlobalConfig text file can be found in each of the folders. This should be tuned to
your camera and network configuration. All the configuration options has to be present on the files
in order for the system to start. The structure of the file is self explanatory.

Two files are provided as an example, GlobalConfig (and standart config to run onboard Quad) and GlobalConfig_EuRoC (for testing the EuRoC dataset).

#### Basic configs in rebvo GlobalConfig

The things you have to configure in order for the system to work.

-- CameraDevice: the v4l2 camera device or dataset camera file and directory

-- ZfX,Y: Camera focal length

-- PPx,y: Camera principal point

-- ImageWidth,Height: size to use

-- Distortion parameters (if enabled)

-- FPS: Frames per Seconds

-- VideoNetHost,Port: IP,Port of the host to send data to

-- SetAffinity flag,CamaraTn: if the flag is set to 1, the system will use the pthread_setaffinity_np() call
to distribute the threads according to the CamaraT1..3 configuration.
This numbers have to point to existing processors or the call wil fail,
and this setting usually require superuser privileges.
Setting affinity and distributing the threads can increase speed.

-- DetectorThresh: This is a fixed threshold to the edge detector only used
if autothresh is off (DetectorAutoGain = 0)
Is a camera dependent parameter so it should be tunned for
best performance.

-- ReferencePoints: If auto thresh is on (DetectorAutoGain>0), number of KL
points to use. Ussual values are 5000 for 320x240 and
15000 for 640x480

-- DetectorMax,MinThresh: Limits on threshold tunning, to prevent excessive
noise on images with no edges. Similar to DetectorThresh,
camera dependant parameters.

-- Imu Mode: 1 for custom IMU, 2 for dataset IMU (EuRoC MAV format)

-- Imu-Camera RotoTraslation file

-- IMU Noise parameters

#### Basic configs in visualizer GlobalConfig

ImageSize, Focal Length and Principal Point should match the config in rebvo.

### System Usage

Just run the two programs on the same o network connected computers and move
the camera trying to maximize translation.

REBVORUN component accept the following command line commands:

q: Quit

r: System full reset

s: Saves in SimVideoFile (rebvo GlobalConfig) SimVideoNFrames frames of
uncompressed video for further replay. It does a direct write to disk,
so it can loose frames depending on the system. The format is described
in videocam.h

p: Takes Snapshot of the current image

The visualizer opens 2 kinds of windows, XLib windows (front and top)
displays the image and the edge detection, OpenGL windows display
the edgemap and the image in a 3D fashion.

#### Commands in the XLib windows

q: Quit

b: Clear trajectory

i: Toggle show image

t: Show frame to frame matching

z,x: Increase/Decease maximum depth in top view

#### Commands in the OpenGL windows

w,s,a,d: Walk the view in a DukeNukem style
arrows: Rotate the view

f,r: flight

1..9: Load i view

Shift+1..9: Save i view

Escape: Reset View

m: Toggle image rendering

n: Toggle edgemap rendering

c: Toggle camera rendering

t,g: Increase/decrease max distance for color scale

y,h: Same for min distance

i: Render edgemap depth uncertainty

v: Render Trajectory

b: Clear trajectory

,: Fix the view to world coordinates

End: Quit

### Output files

If the savelog option is enabled the system outputs 2 files, a .m log file and a
trajectory file (timestamp tx ty tz qx qy qz qw) that can be used to benchmark
the algorithm.

### FAQ

-- Why rebvo doesn't use OpenCV?

OpenCV is great, the system originally used OpenCV for image acquisition
and preprocessing.
Then at some point we figure that it was a waste having to install
the whole library just for image acquisition, so I write small a wrapper
to the V4L2 library trying to make the system easier to install and
less dependent on third party libraries.

### Contact

Juan Jose Tarrio

[email protected]