ROSのツールの1つであるRVizの実行例 | |
初版 | 2007年 |
---|---|
最新版 |
Melodic Morenia
/ 2018年5月23日 |
リポジトリ | |
対応OS | |
対応言語 | |
種別 | ロボットソフトウェアプラットフォーム |
ライセンス | |
公式サイト |
www |
Robot Operating System (ROS) とは、ロボット用のソフトウェアプラットフォームである。ROSはその名に「Operating System」を含むが、Microsoft WindowsやiOSのようなコンピュータのオペレーティングシステム (OS) ではなく、既存のOS上で動くミドルウェアやソフトウェアフレームワークの一種であり、「メタオペレーティングシステム」 (meta-operating system) とも説明される。
ROSはロボットソフトウェアの共同開発を世界規模で推進することを目指している。スタンフォード大学の学生が開発した「Switchyard」プロジェクトを起源にもち、それを引き継いだアメリカのウィローガレージ社が2007年に本格開発を開始し、2010年に最初のリリース版が公開された。その後、非営利団体「オープンソースロボット財団」(現「オープンロボティクス」)が設立され、ROSの開発を主導する役割が引き継がれた。オープンソースソフトウェアとして開発・公開されており、世界中から多くの人々が開発に参加している。
ROSが動作するOSはUbuntuやLinux MintなどのLinuxが中心で、macOS、Windows、Androidでも一部の機能が対応している。ハードウェアの抽象化、低レベルのデバイス制御、汎用的な機能の実装、プロセス間のメッセージ通信、パッケージ管理などを行うほか、ソフトウェアの開発や実行などのためのツールやライブラリを提供する。分散コンピューティングシステムとして設計され、ロボットに必要な様々な計算を複数のプロセスで並列的に行う。各プロセスは単独または複数のコンピュータ上で実行可能であり、処理結果を相互に送受信しながら、1つの大きなソフトウェアシステムとして動作する。ROSのソフトウェアは「コアユーティリティ」と「パッケージ」に分かれており、ユーザは使いたい機能のパッケージを選択してインストールすることで、ロボットに必要な各種機能を利用できる。パッケージは自作することが可能で、ROSはC++やPythonをはじめ、LispやJavaなど多数のプログラミング言語をサポートしている。
ROSを搭載したロボットは、移動ロボットやロボットアームのほか、ヒューマノイド、自動運転車や無人航空機(ドローン)、自律型無人潜水機などと様々である。学術研究を主な対象として開発が始まったROSだが、次第に産業用途にも利用範囲が広がり、ROSを搭載したロボットが製品化され市場に登場するようになっている。新たな利用領域に求められる機能を実装するため、ROSの次世代バージョンである「ROS 2」の開発・リリースも始まっている。
ROSの目標は、ロボットソフトウェア開発におけるコラボレーションを全世界的に推進することである[1][2]。特に、ロボットの研究・開発で用いられるソースコードの再利用性を最大化することを目指して開発された[1][3]。
ROSはハードウェアの抽象化、低レベルのデバイス制御、汎用的な機能の実装、プロセス間のメッセージ通信、パッケージ管理などを行うほか、複数のコンピュータに渡ってプログラムの取得・開発・実行など行うためののツールやライブラリを提供する[4][5]。
ROSはRobot Operating Systemの略だが、この言葉からはROSの実態を正確に把握しにくいとの指摘もある[6]。ROSの情報発信における中心的サイト[7]である「ROS Wiki」では、ROSを「メタオペレーティングシステム」 (meta-operating system) と呼んでいる[8][9]。ROSプロジェクトの中心人物であるブライアン・ガ―キー (Brian Gerkey) は、ROSとは何かという質問に対し「ROS = plumbing(通信)+ tools(ツール群)+ capabilities(機能群)+ ecosystem(エコシステム)」と答え、次のように解説している[10][11][6]。
plumbingとは、いわゆるミドルウェアの通信ライブラリ機能に相当し、capabilitiesとは知能ロボットのライブラリモジュールに相当する[13]。
ROSの起源は、アメリカのスタンフォード大学の学生で人工知能研究所の Stanford AI Robot (STAIR) プロジェクトに参加していたモーガン・クィグリー (Morgan Quigley) が開発した「Switchyard」システムである[14][15]。Switchyardは、ロボット用ソフトウェアを開発するためのフレームワークであり、認識・計画・制御といった知能情報処理をロボット内外で分散処理できるよう並列計算を前提とし、各計算プロセスはピア・ツー・ピアネットワークで非同期通信を行う設計であった[16]。複数の研究者による利用を前提としたモジュール性有し、新しいハードウェアへの適用を考えて、ロボットのハードウェアに依存する部分としない部分を明確に分けた設計がされた[16]。また、Switchyardではソースコードの審美性も重要視されたほか、デプロイシステムを導入するなど、のちに繋がるアイディアが含まれていた[16]。
2007年11月、アメリカのロボット関連民間企業であるウィローガレージ (Willow Garage) 社がSwitchyardの開発を引き継いだ[17][16]。同社は、パーソナルロボットやサービスロボット産業の育成に取り組み、画像処理分野のオープンソースソフトウェア「OpenCV」などの開発支援も行なった企業である[17][16]。さらに、のちにROSのネットワークプログラムに大きな影響を与えるPlayer/Stage プロジェクトの開発者であるブライアン・ガ―キーも加わった[17]。彼らによって Switchyard プロジェクトは ROS として組織化され、ROSがロボット用フレームワークとして多くのユーザを集める最初の転換点となった[16]。
ウィローガレージ社は、オープンソースコミュニティを立ち上げてソフトウェアの共有・連携・再利用を促進する枠組みを構築した[5]。そして同社は、学会や技術者・開発者向けイベントへの支援や参加を積極的に行った[18]。また、初めてROSを利用する技術者向けに、ソフトウェアエンジニアではないヒューマンロボットインタラクション (Human-Robot Interaction; HRI) の専門家とともにマニュアル等の文書整備を推進した[18]。
2010年1月22日にウィローガレージ社は「ROS 1.0」を発表した[19]。2010年3月には、ROSの最初の公式リリースである「ROS Box Turtle」が公開された[20]。その後もアップデートが重ねられ、Linuxのようにディストリビューションとしてリリースされた [20]。同年8月に「C Turtle」、そして2011年3月に「Diamondback」が公開された[20]。
ROS 1.0のリリースと並行して、ウィローガレージ社はROSで制御することを前提としたロボット「PR2」を開発・発表した[21]。PR2は2本のロボットアームを備えた自律移動型の研究用ロボットである[22][23]。そして、ウィローガレージ社はPR2を利用したアプリケーションの開発コンテスト「PR2ベータプログラム」の公募を行なった[21][24]。78の応募の中からアメリカ、ヨーロッパ、日本を中心とした10の大学機関と民間企業1社が採択され、特に優れた提案に対してはPR2が無償で提供された[21][25][26]。2010年9月には、40万ドルでPR2の一般販売も開始されオープンソースコミュニティへの貢献者には12万ドルの割引というインセンティブも与えられた[22]。PR2ベータプログラムが行われた2年間に、ROSで再利用可能なツールやアプリケーションが次々と開発され、全体で2,000以上のROSパッケージがリリースされた[21]。PR2やROSを利用した研究成果を映像化してYouTubeなどに投稿するグループも現れ、メディアの注目を受けたり、そこからROSに興味を持つ研究者が現れたりする好循環が生まれた[25]。これらの施策を通してROSの研究と他のロボット研究とのコラボレーションも進み、ROSの知名度が飛躍的に高められたと評される[21]。
2010年11月には、入門者への敷居を下げてROSの普及を図るため、ロボットキット「TurtleBot」が開発された[27][28]。TurtleBotは、iRobot社のCreateを利用した車輪式の移動ロボットであり、翌年からウィローガレージ社により発売されたほか、オープンソースハードウェアとして設計データが公開された[27][29][30]。
ROSは欧米の学術分野を中心に注目を集め、他のロボット用フレームワークに比べて急速にユーザ数を伸ばした[16][31]。サービスロボットを対象として開発が始まったROSだが、産業用ロボットに利用する動きも見られるようになった[32][33]。ROS-Industrialプロジェクトが立ち上がり、2012年1月にはROS-Industorialの公開リポジトリが開設された[32][33]。
一方で、iRobot社のCEOであるコリン・アングル (Colin Angle) は、ロボットの主要ソフトウェアをオープン化するROSのアプローチは、これまで築き上げてきた重要な知的財産に他国が便乗することを許してしまうと指摘した[34][35]。彼は、ロボット産業にとってROSは危険な存在で事業の収益化に有害であると批判し、今すぐROSをクローズドにすべきと主張した[34][36]。 同じ頃、ワシントン大学の研究グループがソフトウェアにROSを用いた手術ロボットの研究プラットフォーム「Raven-II」を開発し、他大学の研究者らの利用も始まった[37][38]。これに対して、インテュイティヴ・サージカル社が開発した手術ロボット「da Vinci」の特許に関して法律上の問題が指摘された[39][38]。
ウィローガレージ側は、ロボティクス分野においてもウェブ開発におけるLAMPのような基盤が必要であり、それがROSであると主張した[36][40]。さらに同社は、Apacheソフトウェア財団のような非営利団体の設立を検討していると表明した[36][40]。この非営利団体は、寄付を集めて開発者のコミュニティを組織し、独立してROSの管理・維持を行うことを意図したものだった[41][40]。
2012年4月、ウィローガレージ社からROSプロジェクトがスピンアウトされ、非営利団体のオープンソースロボット財団 (Open Source Robotics Foundation; OSRF) が設立された[42]。OSRFのコアミッションは「ロボットの研究・教育・製品開発に、オープンソースソフトウェアを使用するための開発・配布・導入の支援」とされた[42]。2013年2月にウィローガレージ社は、オープンソースでのロボットの研究開発を主導する役割を完全にOSRFへ引き継ぐと発表した[42]。
同年9月には、ROSの開発・管理をOSRFが引き継いで最初のディストリビューションとなる「Hydro Medusa」がリリースされた[43]。これまでは1年に2回のペースでディストリビューションがリリースされていたが、Hydro Medusa 以降は、頻繁なアップデートを望まないユーザの意見を取り入れて、1年に1回の公式リリースとなった [44]。この間、2012年5月には、ROSコミュニティの交流や情報共有を促進するための最初の開発者会議「ROSCon」がアメリカ・ミネソタ州のセントポールで開催され、以降、開催地を変えながら毎年開催されている[45]。
ROSの利用範囲は学術分野を超えて製造・農業・商業分野などに広がり、ROSを搭載したロボットが製品化され市場投入されるまでになった[46][31]。ROSはもともと学術分野での研究利用を主な目的として開発されてきたため、これら新たな利用分野の要求には合わない部分が目立つようになった[46][31]。また、2007年のROSのリリースの後、ROSの要件に適した新技術やソフトウェアライブラリなどの開発・普及も進んだ[46]。ROSの開発者らは、ROSのさらなる発展のために、新たな要件に対応したり、新技術を取り込んだりする方法を検討した[46][31]。その結果、既存のROSを問題なく利用しているユーザへの影響を抑えつつROSの進化を図るため、次世代バージョンは既存のROSと切り離して開発されることとなった[31]。次世代バージョンは、「ROS 2」と名付けられ、2015年8月からアルファ版のリリースが始まり、2016年からベータ版が段階的にリリースされた[47]。そして、2017年12月8日、ROS 2の最初の正式版「Ardent Apalone」がリリースされ、2018年7月2日には更新版の「Bouncy Bolson」がリリースされている[47]。
この間、2017年5月にOSRFは名称を「オープンロボティクス」(Open Robotics) に変更した[48]。
ROSは大学・研究機関といった学術分野をはじめ、産業界や趣味分野まで幅広く利用されている[31]。ROSの利用は、移動ロボットやロボットアームをはじめ、ヒューマノイド、自動運転車や無人航空機(ドローン)、自律型無人潜水機にも広がっている[49]。ROSの利用を公表しているロボットは、ROSの公式サイト[† 2]で紹介されている[50]。その他、企業・研究所・大学・個人などが非公開でROSを利用した多くのロボットを開発している[50]。
2015年に実施されたロボット競技大会であるDARPAロボティクス・チャレンジでは、出場した23チームのうち18チームがROSを利用した[51]。公園や遊歩道といった屋外で1キロメートル以上にわたり移動ロボットに自律走行させる「つくばチャレンジ」[52]では、2017年の大会に参加したチームの3分の2以上がROSを利用した[53]。また、ロボカップの一部門であり、家庭環境での課題達成を競う「ロボカップ@ホーム」[54]では、2016年大会において出場24チームのうち23チームがROSを利用した[53]。そのほかには、アメリカ航空宇宙局 (NASA) が開発し国際宇宙ステーションで稼働したRobonaut 2にもROSが利用されている[55]。
ロボットメーカが開発したロボットでROSに対応しているものは、メーカのコントローラにROSから通信できるインタフェースが用意されていることが多い[56]。2018年現在においては、サーボ機構の制御といったロボットの安全性や信頼性に直結する部分についてはロボットメーカが提供するコントローラを用いることが一般的である[56]。
ROSの入門者向けの標準的なロボットプラットフォームとしてTurtleBotがある[27]。TurtleBotは、教育用プログラミング言語であるLOGOの使用例として制作された亀型ロボットに由来し、ウィローガレージ社の研究者により開発された[27][57]。ROS Wikiで提供されているチュートリアル[† 3]で登場する「turtlesim」も、Logo のプログラム体系を踏襲している[27][57]。
TurtleBotはこれまで初代・2代目・3代目と開発されてきた[27]。いずれも車輪式の移動ロボットで、距離センサやラップトップコンピュータないしシングルボードコンピュータを搭載する[28][27]。初代のTurtleBot1はiRobot社のCreateを利用し、2010年に開発された[27]。2代目のTurtleBot2は2012年に開発され、移動ベースとしてYujin Robot社のiCleboが採用された[27]。3代目のTurtleBot3は、ROBOTIS社のアクチュエータを駆動系に用い、ユーザがパーツを組み替えられるようになっている[27]。TurtleBotはオープンソースハードウェアとして、パーツリストやCADデータが公開されており、ユーザが部品を改良したり3Dプリンタで制作したりできる[58][29]。
ROSを使うためには、ソフトウェアを開発したりロボットを制御したりするコンピュータにROSをインストールする[59]。
ROSが動作するOSはUbuntuやLinux MintなどのLinux系OSが中心で、macOS、Windows、Androidでも一部の機能が対応している[44]。主要なOSについては、ROS Wiki でROSのインストール方法が説明されている[60]。特にUbuntuは、パッケージ管理システムに対応したインストールが可能で、ROS開発チームによるテストが行われることもあり、多く利用されているOSである[44]。
Windows向けには、マイクロソフト社が「ROS1 for Windows」を開発し試験リリースした[61][62]。ROSのインストールやノードの実行が可能であれば、様々なOS上で、異なる言語で実装されたノードを組み合わせてシステムを構築することができる[63]。各ディストリビューションが対応しているプラットフォームは、ROSの公式サイト等で確認できる[† 4]。
ROSは2010年に「ROS 1.0」が発表されて以降アップデートを重ねており、特定のバージョンのファイル群をセットにした「ディストリビューション」としてリリースしている[64]。
かつて、ROSのリリース周期は、対応OSである Ubuntu のリリース周期に合わせて、1年に2回(4月と10月)であった[44]。しかし、2013年にリリースされた「Hydro Medusa」からは、頻繁なアップデートを望まないユーザの意見を取り入れて、公式リリース周期は1年に1回となった[44]。
ROSディストリビューションのサポート期間は2種類ある。Ubuntu と同様に 長期サポート (Long Term Support; LTS) の考え方が取り入れられており、偶数年にリリースされるディストリビューションはLTSとして5年間のサポート、それ以外のサポート期間は2年間である[65][44]。
ROSのディストリビューションは、2番目の「Box Turtle」以降いずれも亀にちなんでおり、頭文字がアルファベット順になっている[66]。ROSのディストリビューションには、それぞれ亀のアイコンが作成されている[66]。また、ROSのロゴにある9個の点も亀の甲羅に由来している[67]。ROSが亀を象徴としたのは、亀の上に乗った象が大地を支えているとする古代の宇宙観にちなんで、知能ロボットの世界においてROSが亀のような役割を果たすようにとの願いが込められている[68]。
ディストリビューション名 | リリース日 | サポート終了日 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Melodic Morenia | 2018年05月23日 | 2023年05月30日 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Lunar Loggerhead | 2017年05月23日 | 2019年05月30日 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Kinetic Kame | 2016年05月23日 | 2021年05月30日 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Jade Turtle | 2015年05月23日 | 2017年05月30日 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Indigo Igloo | 2014年07月22日 | 2019年04月30日 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Hydro Medusa | 2013年09月04日 | 2014年05月31日 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Groovy Galapagos | 2012年12月31日 | 2014年07月31日 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Fuerte Turtle | 2012年04月23日 | -- | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Electric Emys | 2011年08月30日 | -- | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Diamondback | 2011年03月02日 | -- | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
C Turtle | 2010年08月02日 | -- | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Box Turtle | 2010年03月02日 | -- | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
サポート終了 サポート中 現行バージョン 将来のリリース |
ROSのソフトウェアライセンスは、オープンソースソフトウェアの1つであるBSDライセンスやApache 2.0ライセンスを採用している[5][19]。これにより、商用および非商用での利用が可能であるほか、誰でもROSの修正・再利用・再配布ができ、多くのボランティアが開発・改良に参加している[19][69]。
ROSは多種多様のパッケージやツールが複合したソフトウェアシステムである[70][71]。各プログラミング言語に対応する「クライアント層」、具体的なアプリケーションを実装した 「ロボットアプリケーション層」、個別のアプロケーションプログラム作成のための「アプリケーションフレームワーク」、通信を担う「コミュニケーション層」、ハードウェア制御のための「ハードウェアインタフェース層」、開発を支援する「ソフトウェア開発ツール」、そして「シミューレータ」で構成される[70][71]。
ROSのアプリケーションプログラムは「パッケージ」と呼ばれる基本単位で管理される[63]。パッケージは、ROSソフトウェアの基本単位であり、最小実行単位である「ノード」(#計算グラフ上の仕組み参照)を1つ以上持つか、他のパッケージのノードを実行するための設定ファイルを含む[69][72]。各パッケージにはパッケージ情報の管理ファイル、ビルドで用いる設定ファイル、ノードのソースコード、ノード間通信のための設定ファイルなどが含まれる[69][73]。共通の目的のもと複数のパッケージをグループ化した「メタパッケージ」と呼ばれるものもある[74][75]。
ROSのパッケージは公式なものだけでも2,000以上ある[76]。ロボット本体の制御に関するパッケージ、センサに関するパッケージ、駆動部のためのモータ制御に関するパッケージなどがある[50]。センサパッケージはカメラ、深度カメラ、レーザ距離センサ、力/トルクセンサ、音声認識、RFIDなど様々なデバイスに対応したものが公開されている[77]。
ROSにはソフトウェア開発を補助するための様々なツールが用意されている[78][79]。主なツールとしては、GUIユーティリティツールの「rqt」や3次元可視化ツール「RViz」、マニピュレータの動作制御のための統合ライブラリ「MoveIt!」、3次元動力学シミュレータの「Gazebo」用プラグインのほか、後述するビルドシステムやパッケージのリリースツールなどがある[78][80]。
RViz (ROS Visualization) は、ROSの可視化ツールの1つである[81]。視覚化の方法をプラグインとして用意することで、ROSで通信されるデータであれば種類を問わず表示することができる[82]。例えば、測域センサや3次元深度センサといったセンサ情報や、ロボットの形状モデル、地図、これから動作する計画軌道などを3次元表示することができる[81]。
rqtはQtをベースとするGUI環境を提供するツールである[83]。rqtには様々なプラグインが開発されており、ROSの分散プロセスの階層構造や接続関係をグラフ化したり、ロボットの搭載カメラの映像を確認したり、時系列データをグラフにプロットしたりすることが可能である[83]。
MoveIt! は、マニピュレータの動作計画のための高速な順動力学計算やマニピュレーション[† 1]のための高度なアルゴリズム、ロボットハンドの制御などの各種機能を提供するツールである[84]。そして、マニピュレータに対する深い知識がなくても動作生成などを行えるよう、GUI上で設定や操作が行える[84][85]。
Gazeboは、物理エンジンや3次元グラフィックスエンジンを搭載した3次元空間の動力学シミュレータである[86]。ロボットや空間の3次元モデルを読み込み、物理現象やノイズを含めたセンサの挙動などをシミュレートし、3次元映像を表示することができる[86]。GazeboはROSとは独立したソフトウェアだが、ROSを主導しているオープンロボティクスが開発しているため、ROSとの親和性が高い[86]。
ROSのファイルシステムは、インストールフォルダとユーザ作業フォルダに分けられる[87]。インストールフォルダには、ROSの中核プログラムである「roscore」を含むコアユーティリティや、ロボット関連ライブラリ、可視化やシミュレーションのための開発支援ツールなどがインストールされる[88]。ユーザ作業フォルダは、ダウンロードしたパッケージやユーザが自作したパッケージを保存して編集したり、実行可能な形式にビルドしたりする作業スペースである[89]。
ユーザが利用したい機能に応じて必要なパッケージやツールを追加インストールする[90][91]。パッケージは、パッケージ管理ツールを利用してインストールするか、リポジトリからソースコードを取得してビルドする[73]。ROSは分散システムとして設計されており、複数のホスト(コンピュータ)に分散してパッケージをインストールすることも可能である[92]。
既存のパッケージにないハードウェアやアルゴリズムなどを実装するためには、自分でパッケージを作成する。ROSは複数のプログラミング言語に対応している[1]。主要言語はC++やPythonで、そのほかにLisp、Java、Lua、Ruby、Octaveなどでプログラムを開発することができる[93][1][71]。
ソースコードから目的のコードを生成(ビルド)するため、ROSはビルドシステムを有する[94]。初期のビルドシステムは「rosbuild」と呼ばれるものであったが、のちに「catkin」と名付けられた新システムが開発された[95]。ディストリビューション「Groovy Galapagos」からcatkinへの切り替えが始まり、「Hydro Medusa」以降は全システムがcatkinに対応した[95]。catkinはCMakeを修正・拡張したもので、パッケージのビルド、パッケージ管理、依存関係パッケージの自動インストールなどが行える[96]。catkin はビルド結果をソースコードと異なるディレクトリに保存するアウトソースビルド方式を採用し、パッケージの再配布やクロスコンパイルをサポートしたことでソフトウェアの移植性が向上した[94]。
「catkin」という名前は、開発したウィローガレージ社のウィロー(Willow = ヤナギ)の木にみられる尾状花序 (英: catkin) に由来する[97]。
新規に自作したパッケージや、既存のパッケージの改良・修正を行なった場合、リポジトリにコミットしてリリースすることも可能である[98]。ROSはリリースのためのツール「bloom」を提供しており、その使い方を含めたリリース手順は ROS Wiki で説明されている[98]。
ROSはソフトウェアの再利用性を高めるため、分散システムとして設計されている[99][1]。ノードと呼ばれるプロセスが処理結果を送受信しあいながら、ROSは1つの大きなソフトウェアシステムとして動作する[100][1]。ROSのプロセスは、ピア・ツー・ピア型のネットワーク(以下、「ROSネットワーク」と呼ぶ)を構成し、ROSネットワークは計算グラフとして表現できる[101][102]。
ロボットは、センサやユーザインタフェース等から入力した情報を処理して目的遂行のために必要な各種計算を行い、駆動系を制御する。ROSはこれらの演算を「ノード」と呼ばれる比較的小さなプログラムに細分化して実装する[103]。ノードは実行可能な1つのプログラムであり、ROSにおける処理機能の基本単位である[99][103]。センサドライバ、障害物回避、モータの駆動、ナビゲーションといった目的ごとにノードを作成する[103]。各ノードは独立して並列的に動作し、同一ホスト上で全てを実行することも、複数のホストに分散して実行することも可能である[92][1]。
ノード間の接続情報を管理するプログラムを「マスタ」と呼び、登録されたノードが他のノードから見えるようにする役割を担う[51][104][105]。コアユーティリティに含まれるプログラム「roscore」を実行することでマスタが起動される[106][104]。各ノードの起動時に、ノード名やURI、ポート番号といった通信に必要な情報がマスタに登録される[107][108]。マスタはノードから要求があった際に相手先ノードの情報を返し、それを元にノードは相手先ノードとピア・ツー・ピア接続を確立する[107][108]。ROSシステムを実行するためには、ROSネットワークを構築する何れかのホストでマスタを必ず1つ起動しておく必要がある[109][104]。マスタは1つのROSネットワークを構築・管理し、同一のROSネットワーク内で複数のroscoreは起動できない[109][104][51]。マスタが異なるネットワーク間でノード接続を行う場合は別途通信の仕組みを構築する必要がある[51]。
ROSはノード間の通信方法として、単方向非同期通信方式の「トピック」、双方向同期通信方式の「サービス」、双方向非同期通信方式の「アクション」の3種の方式を備える[110]。ROSの配信-購読型のメッセージ通信基盤は、ほぼ完全に独自開発されたものである[111][46]。
ROSの大きな強みの1つとして、ライブラリ群とシェアリングの仕組みを支える活発なコミュニティ活動が挙げられる[122]。世界には様々なロボットソフトウェアプラットフォームがあるが、ROSはコミュニティ活動が特に活発とされる[123]。ROSの開発はオープンロボティクスが単独で行なっているわけではなく、世界中に開かれている[124]。大学や研究機関の研究者、産業界の技術者、さらには趣味でソフトウェアやロボットを開発しているホビイストまで多様な人たちがROSの開発に参加し貢献している[125]。また、ロボットの専門家だけでなく、計算機科学やコンピュータネットワーク、コンピュータビジョンといった分野からも専門家が参加している[125]。
ROS-Industrialとは、ROSを産業用ロボット向けに拡張する取り組みである[133]。ROSはサービスロボット研究の領域で広く利用されるようになった[32]。ROSを利用した知能情報処理機能は産業用ロボット領域へも適用できるものであり、従来は技術的・コスト的に実現困難とされた機能の実装が期待されている[32]。産業用ロボットの持つ信頼性とオープンコミュニティの柔軟性を組み合わせることで、ROSを用いたロボットアプリケーション開発を推進し、産業用ロボットの開発コストの低減や、新規事業化や次世代ロボット市場へのROS適用などを目指している[134][135]。
ROS-Industorialは、オープンソースプロジェクトとして安川電機、ウィローガレージ社、そしてアメリカの独立非営利機関であるサウスウェスト研究所 (SwRI) によって共同で立ち上げられた[33]。2012年1月、ROS-IndustorialのレポジトリがSwRIによってGitHub上に開設された[33]。その後、2013年3月には、ROS-Industrialプロジェクトから発展的にROS-Industrial Consortium(ROS産業コンソーシアム)が設立された[135]。コンソーシアムの中心メンバーは、アメリカではSwRI、ヨーロッパではドイツのフラウンホーファー研究所の生産技術・オートメーション部門 (IPA) 、アジア太平洋地域ではシンガポールのアドバンスト・リマニュファクチャリング・アンド・テクノロジー・センター (Advanced Remanufacturing and Technology Centre; ARTC) および南洋理工大学である[135][33]。2018年10月現在、3M、ボーイング、エアバス、BMW、ボッシュ、シーメンス、ABB、キャタピラー、マイクロソフト、ユニバーサルロボットなどの民間企業のほか、ROS本体の開発を主導する「オープンロボティクス」もコンソーシアムメンバーである[136]。
ROS-Industrialでの研究成果は原則として、BSDライセンスまたはApache 2.0ライセンスで公開される[32]。ただし、ROS産業コンソーシアムには、Focused Technical Projects (FTP) と呼ばれる制度が設けられている[135]。FTPは、コンソーシアム参加企業が特定のテーマを設定して構成する研究グループであり、グループ内で費用や設備を分担し、研究成果を共有する[135]。FTPの研究成果は必ずしも公開されるわけではなく、FTPグループ構成メンバーの審議によって公開の可否やリリース時期を決めることができる[135][137]。ROS-Industrialでの知財マネジメントに関する取り組みと言える[137]。
ROSは、もともと以下の前提のもと設計された[31][46]。
これらは、2007年の開発開始時に設定されたものであり、その後のROSコミュニティの発展により、その利用範囲は製造・農業・商業分野に広がり、ROSを搭載したロボットが製品化されるようになった[139][46]。利用分野の拡大によって、ROSに以下のような新たな要望が寄せられるようになった[139][46]。
また、ROSでは配信-購読型のメッセージ通信基盤を独自開発していたが、その後の技術の発展により、Zeroconf、Protocol Buffers、Data Distribution Service (DDS) といったROSの要件に合ったオープンソースの通信ミドルウェア等が登場した[140][46]。ROSの開発者らは、ROSの次世代化のあり方を検討した結果、既存のROSを問題なく利用しているユーザへの影響を抑えるため、既存のROSと切り離して次世代バージョン「ROS 2」を開発することとなった[31]。
既存のROS (ROS 1) で独自実装だった通信ライブラリは、ROS 2ではData Distribution Service (DDS) に置き換えられた[140]。DDSの採用により実現したセキュア通信、Quality of Service (QoS) 通信、リアルタイム通信、ノード間の相互発見機能はROS 2の特徴とされる[141]。これによりメッセージ通信のリアルタイム性が向上し、ハードウェアとOSがリアルタイム性を持つものであれば、ROSの標準機能でリアルタイム制御を実現できるようになった[142]ほか、単一障害点となりうる「roscore」(マスタ)を必要としないノード間ネットワークを形成可能となった[141]。これらの新機能に対応してROS 2ではAPIが新規設計されたが、 ROS 1との間で相互にメッセージ通信を行うためのブリッジプログラムも用意されており、両者の相互運用も可能である[140]。このほか、ROS 2 ではビルドシステムもアップグレードされ、catkinをベースに「ament」が開発された[142]。
ROS 2は2015年から段階的にアルファ版、ベータ版が公開された[47]。そして、2017年12月に最初のリリース版「Ardent Apalone」が公開され、2018年7月には新バージョン「Bouncy Bolson」が公開された[47]。ROS 2 「Humble Hawksbil」の時点では、Ubuntu (22.04)、RHEL 9/Fedora、macOS、Windowsで利用できる[143]。ROS 2のドキュメントは GitHub 上で公開されており、インストール方法を解説したページも用意されている[† 8]