How to use camera

Introduction

ここではカメラの使い方について説明します.

Camera

通常のWebカメラの場合, UVCと呼ばれる規格に対応したものであればすべて同じように使うことができます. GigEカメラなどドライバが必要なカメラの場合, 別途専用ノードを用意する必要があります.

カメラ画像の出力は, sensor_msgs/Image型の画像と, sensor_msgs/CameraInfo型のカメラパラメータの2つとなり, この2つが組になっていないとうまく動作しません.

3D camera

ここでは三次元情報を計測可能なカメラを三次元カメラと呼びます. 三次元カメラでは三次元点群が出力されます. カラーカメラを持ったものでは画像が合わせて出力されるか, もしくは三次元点群に色情報が追加されます.

三次元点群は sensor_msgs/PointCloud2型のメッセージとして出力されます. これを実際にプログラムで扱うためにはPCLの点群型に変換して使うのが一般的です.

三次元カメラには 2つのカメラを並べてその見え方の差を元に計測を行うステレオカメラ, 赤外線プロジェクタを用いたパターンを投影して距離を計測するカメラ, レーザーの反射にかかる時間を元に距離を計測するToF方式カメラなど, 様々な原理のカメラが存在します. その中でもよく使われるものを紹介します.

Kinect, Xtion Pro Live

KinectやXtionは赤外線パターン投光方式の三次元カメラです. openni2_launchを使いましょう.

roslaunch openni2_launch openni2.launch depth_registration:=true

カラー画像は/camera/rgb/image_rawに, 三次元点群は/camera/depth_registered/pointsに出力されます.

Kinect2

TBD

PlayStation Camera (ps4eye)

PlayStation Cameraはステレオカメラです. USB3.0のコネクタへの改造が必要なほか, カーネルのバージョンやUSBホストのチップとの相性があります. 取り扱うためにはps4eyeというパッケージを使います.

{catkin_workspace}/src以下で,

wstool set ps4eye https://github.com/longjie/ps4eye.git

としてパッケージを取得し,

catkin build ps4eye
source ~/.bashrc

でパッケージをビルドして認識させます. 次に,udevの設定を追加してカメラを認識できるようにします.

rosrun ps4eye create_udev_rules

起動するときは以下のようにします.

roslaunch ps4eye stereo.launch

カラー画像は /stereo/left/image_rect_color/stereo/right/image_rect_colorに, 三次元点群は/stereo/points2に出力されます.

How to visualize

カメラ画像の場合,image_viewを使って画像の内容を見ることができます.

rosrun image_view image_view image:={topic name}

三次元点群の場合はrvizを使いましょう.

rosrun rviz rviz

して, Global OptionFixed Frameをカメラとつながっているフレームにし, Add -> By Topic -> PointCloud2を追加して, Topicを変更することで表示することができます.

Camera calibration

カメラを使いはじめるときは,キャリブレーションが必要です. キャリブレーションでは,焦点距離などの内部パラメータ推定,歪み補正, ステレオなど複数台のカメラ間やロボットに対する カメラの位置姿勢を求める外部パラメータ推定を行います. ROS Camera Calibration Tutorialsを参照してください.

(カメラによっては工場出荷状態でキャリブレーションされているものもあります.)

Monocular camera

単一のカメラでは,内部パラメータ推定と歪み補正を行います. How to Calibrate a Monocular Cameraを参照してください.

Stereo camera

ステレオカメラでは,それぞれのカメラでのキャリブレーションに加えて 外部パラメータ推定と平行化を行います. How to Calibrate a Stereo Cameraを参照してください.

Calibrated Images

カメラキャリブレーションを行った場合の注意点として, カメラから受け取った生のカメラ画像は /{camera_name}/image_rawに出力されますが, キャリブレーションされた画像は {camera_name}/image_rect_colorに出力されます. {camera_name}/camera_infoの中にはキャリブレーションによって求められた 内部パラメータや歪み補正の値が含まれています.