A cross-platform library for capturing data with the RealSense F200 (IVCAM 1.0, 1.5) and RealSense R200 (DS4). This effort is aimed at supporting prototyping efforts on new platforms and form-factors (robots, drones, VR, etc). This repository hosts both the source-code and binary releases.
Dependency management for GLFW3 and libusb-1.0 is done manually at the moment (see the corresponding sections below), pending the creation of installer scripts to automate the process.
NB: On Linux, the libusb/libuvc backend has been deprecated in favor of the V4L2 backend.
- (DS4) ALL of 640x480, 628x468, 492x372, 480x360, 332x252, 320x240 are now available for DEPTH and INFRARED streams.
- (DS4/IVCAM) It is safe to hardcode 640x480 or 320x240 as DEPTH or INFRARED resolutions, supported on both DS4 and IVCAM.
- (DS4) For the resolutions which are 12 pixels larger than the native depth resolution, the depth image is centered and padded.
- (DS4) For the resolutions which are 12 pixels smaller than the native infrared resolution, the IR image is cropped and centered.
- (All) If the same resolution is requested for DEPTH and INFRARED streams, they will be pixel-for-pixel aligned and have the same intrinsics.
- New stream mode: RECTIFIED_COLOR – Equivalent to DSAPI’s rectified third modes, removes COLOR image distortion and cancels out rotation relative to DEPTH stream.
- Suitable for use as a background for augmented reality rendering, images produced via rectilinear perspective projection will overlay RECTIFIED_COLOR images correctly.
- New stream mode: DEPTH_ALIGNED_TO_RECTIFIED_COLOR – Maps data coming from the DEPTH stream to match the intrinsic and extrinsic camera properties of the DEPTH stream.
- Suitable for pre-loading the depth map for augmented reality rendering, or performing tracking that needs to be pixel accurate with the RECTIFIED_COLOR image.
- RealSense R200 (DS4)
- RealSense F200 (IVCAM 1.0)
- RealSense SR300 (IVCAM 1.5)
DS5 support will be provided in the near future. librealsense should in principal be able to support any 3D camera which exposes a UVC interface and which chiefly relies on UVC XU commands and USB sidechannel traffic for controls and calibration information.
librealsense is written in standards-conforming C++11 and relies only on the C89 ABI for its public interface. It was developed and tested on the following platforms:
- Windows 8.1 (Visual C++ 2013)
- Ubuntu 14.04 LTS with an updated 4.2.3 kernel (gcc toolchain)
- Mac OS X 10.7+ (clang toolchain)
- Neither the libuvc or V4L2 backend has been validated on Ubuntu 12.04 LTS or Ubuntu 15.10, and several attempts to bring cameras up on these platforms have revealed underlying OS bugs and issues.
It may be possible to compile and run librealsense on other platforms. Please let us know if you do, as well as any steps you found necessary to do so, so that we can update this list.
- C - Core library API exposed via the C89 ABI
- C++ - Single header file (rs.hpp) wrapper around C API, providing classes and exceptions
- C# - Single source file (rs.cs) wrapper for P/Invoke to C API, providing classes and exceptions
- Java - Source files (com/intel/rs/*.java + rs-jni.c) providing a JNI wrapper over C API, providing classes and exceptions, out parameters emulated via Out wrapper class
- Requires librealsense.so / realsense.dll to be compiled on a machine with the JDK installed
- Python - Single source file (rs.py) wrapper using ctypes to access C API, providing classes and exceptions; out parameters converted to return values using Python tuples
Our intent is to provide bindings and wrappers for as many languages and frameworks as possible. Our core library exposes its functionality via C, and we intend for our various bindings and wrappers to look and feel "native" to their respective languages, for instance, using classes to represent objects, throwing exceptions to report errors, and following established naming conventions and casing styles of the language or framework in question.
The goal of librealsense is to provide a reasonable hardware abstraction with minimal dependencies. It is not a computer vision SDK.
- Native streams: depth, color, infrared
- Synthetic streams: rectified images, depth aligned to color and vice versa, etc.
- Intrinsic/extrinsic calibration information
- Majority of XU-exposed functionality for each camera
- Full multi-camera capture, even mixing device types (F200 and R200)
- Install XCode 6.0+ via the AppStore
- Install the Homebrew package manager via terminal - link
- Install libusb via brew:
brew install libusb
- Install glfw3 via brew:
brew tap homebrew/versions
brew install versions/glfw3
- Ensure apt-get is up to date
sudo apt-get update && apt-get upgrade
- Install libusb-1.0 via apt-get
sudo apt-get install libusb-1.0-0-dev
- glfw3 is not available in apt-get on Ubuntu 14.04. Use included installer script:
scripts/install_glfw3.sh
- Follow the installation instructions for your desired backend (see below)
- We use QtCreator as an IDE for Linux development on Ubuntu
- NB: QtCreator is presently configured to use the V4L2 backend by default
sudo apt-get install qtcreator
sudo scripts/install_qt.sh
(we also need qmake from the full qt5 distribution)all.pro
contains librealsense and all example applications- From the QTCreator top menu: Clean => Run QMake => Build
- Built projects will be placed into
./bin/debug
or./bin/release
- We also provide a makefile if you'd prefer to use your own favorite text editor
make && sudo make install
- The example executables will build into
./bin
- Install a recent kernel version (4.2.3 is known to work)
- Run the following script to patch uvcvideo.ko
scripts/patch-uvcvideo-kernel-object.sh
- This script involves cloning the Linux source repository (about 1GB), and may take a while
The libuvc backend requires that the default linux uvcvideo.ko driver be unloaded before libusb can touch the device. This is because uvcvideo will attachthe moment it is unplugged in, and user-space applications do not have permission to access the device. See below regarding the udev rule workaround.
LibUVC is known to have issues with particular versions of SR300 and DS4 firmware (1.0.7x.xx are problematic).
- Grant appropriate permissions to detach the kernel UVC driver when a device is plugged in:
sudo cp config/99-uvc.rules /etc/udev/rules.d/
sudo cp config/uvc.conf /etc/modprobe.d/
- Either reboot or run
sudo udevadm control --reload-rules && udevadm trigger
to enforce the new udev rules
- Use the makefile to build the LibUVC backend
make BACKEND=LIBUVC
sudo make install
Q: How is this implemented?
A: The library communicates with RealSense devices directly via the UVC and USB protocols. It does not link against DSAPI or IVCAM-DLL. Most of the library source code is platform agnostic, but there is a small UVC abstraction layer with platform-specific backends, including:
- A LibUVC backend which provides user-space access to UVC devices on Linux and Mac OS X
- A Video4Linux backend which provides kernel-space access to UVC devices on Linux
- A Windows Media Foundation backend which provides kernel-space access to UVC devices on Windows , a Video4, using Media
Q: Is it maintained or supported?
A: It is supported in the sense that bugs will be fixed if they are found and new features will be periodically added. It is not intended to replace functionality developed by other teams to support HVM (firmware updates, etc), nor materially impact SSG’s roadmap for the SDK/DCM – it is independent and outside of these major efforts.
Example | Platform | Description |
---|---|---|
c-capture | All | Basic example using the C API to pull depth, color, and IR |
c-enumerate | All | A commandline application (no window) to describe properties and resolutions of all connected cameras |
c-pointcloud | All | Demonstration of pointcloud projection using the C API (projects all available streams) |
cpp-capture | All | Basic example using the C++ API to pull depth, color, and IR |
cpp-multicam | All | For all connected cameras, draw depth and color streams (limited by window size) |
cpp-pointcloud | All | Demonstration of pointcloud projection using the C++ API (click to change the stream source: color, depth, or IR) |
cpp-alignimages | Windows | Shows the use of synthetic streams (color aligned to depth, depth aligned to color) |
cpp-restart | Windows | Runtime re-configuration of streaming modes (start, stop, reconfigure, start, etc) |
cs-capture | Windows | Basic example to pull depth, color, and IR images in C#. |
For internal distribution only.
("Material") are owned by Intel Corporation or its suppliers or licensors. Title to the Material remains with Intel Corporation or its suppliers and licensors. The Material may contain trade secrets and proprietary and confidential information of Intel Corporation and its suppliers and licensors, and is protected by worldwide copyright and trade secret laws and treaty provisions. No part of the Material may be used, copied, reproduced, modified, published, uploaded, posted, transmitted, distributed, or disclosed in any way without Intel’s prior express written permission.
No license under any patent, copyright, trade secret or other intellectual property right is granted to or conferred upon you by disclosure or delivery of the Materials, either expressly, by implication, inducement, estoppel or otherwise. Any license under such intellectual property rights must be express and approved by Intel in writing.
Copyright © 2015 Intel Corporation. All rights reserved.