Skip to content

Latest commit

 

History

History
155 lines (104 loc) · 4.28 KB

README.md

File metadata and controls

155 lines (104 loc) · 4.28 KB

Tests Passing GitHub Contributors Issues

[Documentation]

Deoxys Vision Utils

A package to use cameras in ros-independent manner. Currently internal use within UT RPL group.

Authors

Yifeng Zhu, Zhenyu Jiang

Installation

pip install -e .

Development

Enable auto formatting.

pip install pre-commit
pre-commit install

Usage

Running the camera nodes through redis server

python

Hand-Eye Camera Calibration

Interfaces

Kinect Interface

Before we begin, there are several prerequisites if you build k4a SDK from source:

sudo apt install ninja-buil libsoundio-dev

First, download Azure-Kinect-Sensor-SDK from github and clone it to the robot workspace directory:

git clone https://github.com/microsoft/Azure-Kinect-Sensor-SDK

Follow the instructions in the README file and build, referring to the building page.

Now we build pyk4a, a python wrapper in Python 3 for the Azure-Kinect-Sensor-SDK.

Clone the pyk4a repo from github:

git clone https://github.com/etiennedub/pyk4a.git

Install pyk4a for python wrappers. Make sure to change $ROBOT_WS to the robot workspace directory.

pip install -e . --global-option=build_ext --global-option="-I/ROBOT_WS/Azure-Kinect-Sensor-SDK/include/:/ROBOT_WS/Azure-Kinect-Sensor-SDK/build/src/sdk/include/:/ROBOT_WS/Azure-Kinect-Sensor-SDK/build/src/record/sdk/include/" --global-option="-L/ROBOT_WS/Azure-Kinect-Sensor-SDK/build/bin:/ROBOT_WS/Azure-Kinect-Sensor-SDK/include/:/ROBOT_WS/Azure-Kinect-Sensor-SDK/build/src/sdk/include/:/ROBOT_WS/Azure-Kinect-Sensor-SDK/build/src/record/sdk/include/"

Also put libdepthengine.so.2.0 under build/bin. (Take this file from Debian package file.)

And also, remember to create the udev rules (copy 99-k4a.rules file under /etc/udev/rules.d/)

Also, add the link path to k4a:

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$DEOXYS_VISION_DIR/third_party/Azure-Kinect-Sensor-SDK/build/bin/:$DEOXYS_VISION_DIR/third_party/Azure-Kinect-Sensor-SDK/include/:$DEOXYS_VISION_DIR/third_party/Azure-Kinect-Sensor-SDK/build/src/sdk/include/:$DEOXYS_VISION_DIR/third_party/Azure-Kinect-Sensor-SDK/build/src/record/sdk/include/

Realsense

$ git clone https://github.com/IntelRealSense/librealsense.git
$ cd ./librealsense

Discconnect your realsense device, and do:

./scripts/setup_udev_rules.sh

Now let's build the repo

mkdir build && cd build

Run cmake with python binding option:

cmake ../ -DBUILD_PYTHON_BINDINGS:bool=true

Then switch to your python virtualenvironment, do:

cmake ../ -DBUILD_PYTHON_BINDINGS:bool=true

Now you should be able to use pyrealsense2.

Update calibration parameters

/usr/bin/Intel.Realsense.CustomRW -sn 017322071705 -w -f update_calibration.xml

Usage

Under the main folder, run:

python scripts/deoxys_camera_node.py --camera-ref rs_0 --use-rgb
--use-depth --eval --use-rec --visualization

If you want to specify ip (e.g. localhost), you should add an argument --host IP_ADDR

Currently we use redis server. Follow the instruction of their official documentation. After installation, edit the file /etc/redis/redis.conf with sudo access, comment out the original line of bind 127.0.0.1 ::1 and add a new line that binds to your own IP.