ROS探索總結(一)——ROS簡介

一、歷史

       隨着機器人領域的快速發展和複雜化,代碼的複用性和模塊化的需求原來越強烈,而已有的開源機器人系統又不能很好的適應需求。2010年Willow Garage公司發佈了開源機器人操作系統ROS(robot operating system),很快在機器人研究領域展開了學習和使用ROS的熱潮。


       ROS系統是起源於2007年斯坦福大學人工智能實驗室的項目與機器人技術公司Willow Garage的個人機器人項目(Personal Robots Program)之間的合作,2008年之後就由Willow Garage來進行推動。已經有四年多的時間了 (視頻)。隨着PR2那些不可思議的表現,譬如疊衣服,插插座,做早飯,ROS也得到越來越多的關注。Willow Garage公司也表示希望藉助開源的力量使PR2變成“全能”機器人。

       PR2價格高昂,2011年零售價高達40萬美元。PR2現主要用於研究。PR2有兩條手臂,每條手臂七個關節,手臂末端是一個可以張合的鉗子。PR2依靠底部的四個輪子移動。在PR2的頭部,胸部,肘部,鉗子上安裝有高分辨率攝像頭,激光測距儀,慣性測量單元,觸覺傳感器等豐富的傳感設備。在PR2的底部有兩臺8核的電腦作爲機器人各硬件的控制和通訊中樞。兩臺電腦安裝有Ubuntu和ROS。


二、設計目標

       ROS是開源的,是用於機器人的一種後操作系統,或者說次級操作系統。它提供類似操作系統所提供的功能,包含硬件抽象描述、底層驅動程序管理、共用功能的執行、程序間的消息傳遞、程序發行包管理,它也提供一些工具程序和庫用於獲取、建立、編寫和運行多機整合的程序。

       

       ROS的首要設計目標是在機器人研發領域提高代碼複用率。ROS是一種分佈式處理框架(又名Nodes)。這使可執行文件能被單獨設計,並且在運行時鬆散耦合。這些過程可以封裝到數據包(Packages)和堆棧(Stacks)中,以便於共享和分發。ROS還支持代碼庫的聯合系統。使得協作亦能被分發。這種從文件系統級別到社區一級的設計讓獨立地決定發展和實施工作成爲可能。上述所有功能都能由ROS的基礎工具實現。


三、主要特點

       ROS的運行架構是一種使用ROS通信模塊實現模塊間P2P的鬆耦合的網絡連接的處理架構,它執行若干種類型的通訊,包括基於服務的同步RPC(遠程過程調用)通訊、基於Topic的異步數據流通訊,還有參數服務器上的數據存儲。但是ROS本身並沒有實時性。

       ROS的主要特點可以歸納爲以下幾條:

     (1)點對點設計


       一個使用ROS的系統包括一系列進程,這些進程存在於多個不同的主機並且在運行過程中通過端對端的拓撲結構進行聯繫。雖然基於中心服務器的那些軟件框架也可以實現多進程和多主機的優勢,但是在這些框架中,當各電腦通過不同的網絡進行連接時,中心數據服務器就會發生問題。
      ROS的點對點設計以及服務和節點管理器等機制可以分散由計算機視覺和語音識別等功能帶來的實時計算壓力,能夠適應多機器人遇到的挑戰。

       (2)多語言支持

       在寫代碼的時候,許多編程者會比較偏向某一些編程語言。這些偏好是個人在每種語言的編程時間、調試效果、語法、執行效率以及各種技術和文化的原因導致的結果。爲了解決這些問題,我們將ROS設計成了語言中立性的框架結構。ROS現在支持許多種不同的語言,例如C++、Python、Octave和LISP,也包含其他語言的多種接口實現。


       ROS的特殊性主要體現在消息通訊層,而不是更深的層次。端對端的連接和配置利用XML-RPC機制進行實現,XML-RPC也包含了大多數主要語言的合理實現描述。我們希望ROS能夠利用各種語言實現的更加自然,更符合各種語言的語法約定,而不是基於C語言給各種其他語言提供實現接口。然而,在某些情況下利用已經存在的庫封裝後支持更多新的語言是很方便的,比如Octave的客戶端就是通過C++的封裝庫進行實現的。
       爲了支持交叉語言,ROS利用了簡單的、語言無關的接口定義語言去描述模塊之間的消息傳送。接口定義語言使用了簡短的文本去描述每條消息的結構,也允許消息的合成,例如下圖就是利用接口定義語言描述的一個點的消息:


       每種語言的代碼產生器就會產生類似本種語言目標文件,在消息傳遞和接收的過程中通過ROS自動連續並行的實現。這就節省了重要的編程時間,也避免了錯誤:之前3行的接口定義文件自動的擴展成137行的C++代碼,96行的Python代碼,81行的Lisp代碼和99行的Octave代碼。因爲消息是從各種簡單的文本文件中自動生成的,所以很容易列舉出新的消息類型。在編寫的時候,已知的基於ROS的代碼庫包含超過四百種消息類型,這些消息從傳感器傳送數據,使得物體檢測到了周圍的環境。
       最後的結果就是一種語言無關的消息處理,讓多種語言可以自由的混合和匹配使用。

       (3)精簡與集成

       大多數已經存在的機器人軟件工程都包含了可以在工程外重複使用的驅動和算法,不幸的是,由於多方面的原因,大部分代碼的中間層都過於混亂,以至於很困難提取出它的功能,也很難把它們從原型中提取出來應用到其他方面。
      爲了應對這種趨勢,我們鼓勵將所有的驅動和算法逐漸發展成爲和ROS沒有依賴性單獨的庫。ROS建立的系統具有模塊化的特點,各模塊中的代碼可以單獨編譯,而且編譯使用的CMake工具使它很容易的就實現精簡的理念。ROS基本將複雜的代碼封裝在庫裏,只是創建了一些小的應用程序爲ROS顯示庫的功能,就允許了對簡單的代碼超越原型進行移植和重新使用。作爲一種新加入的有優勢,單元測試當代碼在庫中分散後也變得非常的容易,一個單獨的測試程序可以測試庫中很多的特點。
       ROS利用了很多現在已經存在的開源項目的代碼,比如說從Player項目中借鑑了驅動、運動控制和仿真方面的代碼,從OpenCV中借鑑了視覺算法方面的代碼,從OpenRAVE借鑑了規劃算法的內容,還有很多其他的項目。在每一個實例中,ROS都用來顯示多種多樣的配置選項以及和各軟件之間進行數據通信,也同時對它們進行微小的包裝和改動。ROS可以不斷的從社區維護中進行升級,包括從其他的軟件庫、應用補丁中升級ROS的源代碼。

       (4)工具包豐富

       爲了管理複雜的ROS軟件框架,我們利用了大量的小工具去編譯和運行多種多樣的ROS組建,從而設計成了內核,而不是構建一個龐大的開發和運行環境。
       這些工具擔任了各種各樣的任務,例如,組織源代碼的結構,獲取和設置配置參數,形象化端對端的拓撲連接,測量頻帶使用寬度,生動的描繪信息數據,自動生成文檔等等。儘管我們已經測試通過像全局時鐘和控制器模塊的記錄器的核心服務,但是我們還是希望能把所有的代碼模塊化。我們相信在效率上的損失遠遠是穩定性和管理的複雜性上無法彌補的。

       (5)免費並且開源

      ROS所有的源代碼都是公開發布的。我們相信這將必定促進ROS軟件各層次的調試,不斷的改正錯誤。雖然像Microsoft Robotics Studio和Webots這樣的非開源軟件也有很多值得讚美的屬性,但是我們認爲一個開源的平臺也是無可爲替代的。當硬件和各層次的軟件同時設計和調試的時候這一點是尤其真實的。
      ROS以分佈式的關係遵循這BSD許可,也就是說允許各種商業和非商業的工程進行開發。ROS通過內部處理的通訊系統進行數據的傳遞,不要求各模塊在同樣的可執行功能上連接在一起。如此,利用ROS構建的系統可以很好的使用他們豐富的組件:個別的模塊可以包含被各種協議保護的軟件,這些協議從GPL到BSD,但是許可的一些“污染物”將在模塊的分解上就完全消滅掉。

參考資料:
(1)《開源機器人操作系統——ROS》 張建偉等著
(2)《an open-source Robot Operating System》 paper
(3)  willowgarage公司網站:http://www.willowgarage.com/
(4)  ROS官方wiki:http://www.ros.org

----------------------------------------------------------------

歡迎大家轉載我的文章。

轉載請註明:轉自古-月

http://blog.csdn.net/hcx25909

歡迎繼續關注我的博客


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章