オープンソースのロボットアプリケーションフレームワーク『ROS (Robot Operating System)』

ちょっと前からロボット関係で話題(?)になっていたROS(Robot Operating System)というものについて調べ始めた。名前からしてロボット用のOSなのかと思ったらそうじゃなくて、Linux(Ubuntu)上で動くミドルウェアというかフレームワークという位置づけらしい。

ROS.org

ソフトウェア開発者のロボット・アプリケーション作成を支援するライブラリとツールを提供しています. 具体的には, ハードウェア抽象化, デバイスドライバ,ライブラリ,視覚化ツール, メッセージ通信,パッケージ管理などが提供されています. ROSはオープンソースの一つ, BSDライセンスにより, ライセンス化されています.

公式ドキュメントの日本語化が進んでいるのもありがたいですね。動作環境は基本的にUbuntu推奨で、試験的にOSXとかもサポートしているけど、Ubuntuでやっておいた方が無難でしょうね。
聞くところによると、もともとPoint Cloud LibraryはROSの一部だったものが独立のライブラリ化したという経緯があるらしいです。

ROS公式ドキュメント以外だと、今のところ日本語で発売されている唯一のROS参考書はコレ↓

ROSではじめるロボットプログラミング―フリーのロボット用「フレームワーク」 (I・O BOOKS)

著者の方のブログはこちら↓
http://ros-robot.blogspot.jp/

ロボットを制御するためのソフトウェアって、アルゴリズムなどの専門分野が多岐にわたるから、こういうフレームワークがないとプロトタイプすらしんどいだろうな。(フレームワークがあってもしんどいだろうけど)

オイラがROSに期待しているのは、ロボットの制御というよりは画像認識系のアルゴリズムの組み合わせも手軽にできるようになる点。最近は、ルンバなどのお掃除ロボットにもSLAM的な空間認識機能が付いてたりするけど、ああいった機能が程よく抽象化されて利用できるのが利点だと思う。(まだ試してないけど)



実は、少し前からこの「ROSではじめるロボットプログラミング」を読んで真似してて、やっと第7章まで来た。

そして、発売されている書籍以外だと、最近出たクリエイティブ・コモンズの無料書籍がある。こちらにはSLAMの例が載っているのでいずれ真似してみたい。↓

詳説 ROSロボットプログラミング

詳説 ROSロボットプログラミング

ちなみに、このROSのバージョン名はすべて亀にちなんだ名称になっていて、どちらの書籍もバージョンIndigoを解説対象としている。とりあえずIndigoで始めておいた方がつまずきにくいと思う。Ubuntuのバージョンは14.04。

ROSを講義で扱ってる中部大学 工学部 ロボット理工学科ってすごい実践寄りなだよな。



さて、このROSに対して同じくロボット系のOpenRTMっていうフレームワークもあるらしいけど、そっちはどうなんでしょうね。

RTMではじめるロボットアプリ開発 (I・O BOOKS)

関連記事

海外ドラマのChromaKey

hloc:SuperGlueで精度を向上させたSfM・Visual Localization

Mask R-CNN:ディープラーニングによる一般物体検出・Instance Segmentatio...

MVStudio:オープンソースのPhotogrammetryツール

SONYの自律型エンタテインメントロボット『aibo』

網元AMIで作ったWordpressサイトのインスタンスをt1microからt2microへ移行した

WordPressプラグインによるサイトマップの自動生成

OpenGVのライブラリ構成

UnrealCV:コンピュータビジョン研究のためのUnreal Engineプラグイン

AnacondaとTensorFlowをインストールしてVisual Studio 2015で使う

OpenCV 3.1のsfmモジュールのビルド再び

Polyscope:3Dデータ操作用GUIライブラリ

Raspberry PiでIoTごっこ

VCG Library:C++のポリゴン操作ライブラリ

WordPressプラグインの作り方

Boost オープンソースライブラリ

Point Cloud Utils:Pythonで3D点群・Meshを扱うライブラリ

OpenCVで顔のランドマークを検出する『Facemark API』

Python for Unity:UnityEditorでPythonを使えるパッケージ

openMVG:複数視点画像から3次元形状を復元するライブラリ

Mitsuba 2:オープンソースの物理ベースレンダラ

adskShaderSDK

Kinect for Windows v2の日本価格決定

OpenCV

チャットツール用bot開発フレームワーク『Hubot』

iPhone x ロボットハッカソン~RomoのiPhone用SDKで目覚ましアプリを作る~

プログラムによる景観の自動生成

OpenCVのバージョン3が正式リリースされたぞ

Rerun:マルチモーダルデータの可視化アプリとSDK

第25回コンピュータビジョン勉強会@関東に行って来た

Faster R-CNN:ディープラーニングによる一般物体検出手法

Raspberry Piでセンサーの常時稼働を検討する

OpenCV 3.1のsfmモジュールを試す

Kinect for Windows V2のプレオーダー開始

Twitter APIのPythonラッパー『python-twitter』

libigl:軽量なジオメトリ処理ライブラリ

Raspberry Pi

NeuralNetwork.NET:.NETで使えるTensorFlowライクなニューラルネットワー...

HerokuでMEAN stack

GeoGebra:無料で使える数学アプリ

Webサイトのワイヤーフレームが作成できるオンラインツール

顔検出・認識のAPI・ライブラリ・ソフトウェアのリスト

コメント