以嵌入式Linux開發平臺為基礎,根據模糊控制算法進行機器人路徑規劃,同時將兩自由度云臺和超聲波測距模塊相結合,擴大了障礙物檢測范圍。根據測試,移動機器人可以根據操作人員的語音指令,實現前進、后退、測量距離等動作,并通過MP3播放功能播放出所測量到的距離值和機器人當前的運行狀態。在運行過程中,機器人可以自動檢測方位并修正,實現無碰撞行駛。
隨著科學技術的發展和社會的需要,移動機器人技術得到了迅速發展,正在滲透到各行各業中,使人們的生活更加便利。現今以單片機為核心的移動機器人存在處理數據量有限、控制系統速度低、人機交互機制單一等缺點,不能滿足機器人多任務的要求。系統中增加協處理器的系統結構也得到了廣泛應用,雖然可以管理多種傳感器,但這種結構卻增加了硬件的冗余度和復雜度
移動機器人屬于能夠自動執行工作任務的機器,不但能夠按照事先編譯的程序運行,同時人類還可對其指揮。當前主要被運用在生產業、建筑業以及航空航天領域,而該領域的發展情況直接關系到國家綜合實力的提升速度,對此加強對移動機器人控制系統的發展情況,以及未來發展方向的研究勢在必行。?
國內外常見的移動機器人控制系統??
相對于國內在移動機器人的研究狀況,能夠看出國外在該領域的研究是較早的,其中具有代表性的有Saphira、TeamBots以及ISR。而在國內方面,代表性的有OSMOR、ZJMR以及Agent。下面,便對較為常用的控制系統進行介紹:??
1.1?國外移動機器人控制系統????
1.1.1?Saphira控制系統??
Saphira控制系統是移動機器人領域中最早的系統,是有SRI國際人工智能中心在1990年所研發的,此系統是基于本地感知空間的共享內存與黑板,來實現協調與通信進程。由于Saphira是采用C語言來進行開發的,同時支持Windows與Unix系統,因此具有文檔資料相對完整、系統資源占用少等特征。但是需注意的是,由于Saphira系統在定位方面無法達到當前的實際需求,因此運用是相對較少的。???
1.1.2?TeamBots控制系統??
本系統是基于Java包與Java應用程序而構建的,經過20余年的發展后,此系統截止到目前已經被運用到多種類型的機器人平臺當中。除此之外,在適用的操作系統方面,其中具有代表性的有Windows、MacOS以及Linux等,因此其運用的范圍是更加廣泛的。???
1.1.3?ISR控制系統??
ISR是基于行為的控制模式,其中是有任務執行層、反映層以及推理層所構成的,是有CAS研究中心所研發的。其中,任務執行層的作用是執行推理層所傳輸的指令;反映層其中包含資源、控制器以及行為;推理層的功能是根據用戶的指令來對決策進行制定。此外,ISR控制系統僅能夠在Linux中進行操作,并且沒有公開化使用。???
1.2?國內移動機器人控制系統??
OSMOR是我國首個機器人系統,此系統在傳感器處理方面具有明顯的優勢,并且為了能夠防止出現數據處理的復雜性與傳感器多樣性的影響,本控制系統將傳感器數據的處理劃分為單獨結構當中。但是需注意的是,OSMOR屬于沈陽自動化研究所的實驗室自主開發的機器人系統,因此被沒有得到廣泛的運用。??
與此同時,我國各個高校也加大了對移動機器人的研究力度。其中,浙江大學構建了ZJMR系統;中南大學研究了室外自主導航系統;南京理工大學經過研究后,提出了Agent系統。河海大學提出了集控式足球機器人系統;東北大學研發了基于自主式足球機器人的底層控制系統;清華大學是基于多機器人協作的層面為核心,并構建了系統框架,由于此框架不夠成熟,因此并沒有運用到市場中。???
基于嵌入式Linux的移動機器人控制系統
1 控制系統硬件設計
控制系統選用兩輪獨立驅動小車為移動式機器人平臺,后輪為一個尼龍萬向輪。處理器為三星公司的S3C2440,系統主頻最高可達533 MHz,外接512 MB的NAND Flash和64 MB的SDRAM,支持SPI、I2C、UART等接口,滿足移動機器人控制系統的需求,如圖1所示。
圖1 系統硬件組成
整個控制系統工作過程如下:語音識別芯片LD3320通過SPI總線接口接人ARM 處理器,處理器可以對識別的結果進行分析和匯總,并通過查表提取出操作人員的命令碼;同時,處理器通過串口讀取機器人當前的航向信息;超聲波測距和紅外線地面檢測模塊由處理器的GPIO 引腳控制;通過控制兩自由度的云臺,可以進行多方位的超聲波障礙物檢測,利用LD3320模塊的MP3播放功能播放所檢測到的障礙物距離和路況信息。控制系統根據傳感器的數據和所識別的操作人員的命令碼,利用信息融合技術提取環境特征,通過路徑規劃技術作出決策,控制電機狀態,最終控制機器人的姿態。
2 控制系統軟件設計
在軟件設計中,將系統中所有要處理的任務劃分為不同的、相互獨立的任務模塊。根據系統的性能指標和技術要求,可將任務劃分為:語音識別、航向測量與計算、超聲波測距、電機控制、信息處理等任務。
2.1 進程的創建與狀態轉換
移動機器人控制系統在初始化完成后,利用系統調用fock機制分別為語音識別、航向測量與計算和超聲波測距等任務產生相應的子進程,實現方式如圖2所示。進程創建成功后,操作系統會根據調度算法進行進程調度,這使系統在行駛過程中,能夠及時響應語音命令。
圖2 系統多進程設計的實現方式
2.2 進程間通信機制
在信息處理進程中,需要對不同任務返回的有效數據進行信息處理和融合。由于不同進程的數據段、堆棧段是相互隔離的,因此,采用共享內存的進程間通信方式,在程序中可以使用shmget從系統中取出一塊未使用的物理內存并映射到用戶空間,如圖3所示。
圖3 共享內存機制示意圖 在兩個進程之間建立共享內存的具體實現步驟如下:
① 在調用fock()前,使用shmget創建新的共享內存,返回值為共享內存標識碼:
shmid = shmget(IPC_PRIVATE,1,PERM)
//申請一個字節共享內存
② 調用fock()函數,創建子進程,根據fock()的返回值區分父進程和子進程,并分別在兩個進程中使用shmat映射一塊共享內存,即允許當前進程訪問創建的共享內存:
if(fock()) p_addr= shmat(shmid,0,0);
//將共享內存映射到父進程
else{c_addr=shmat(shmid,0,0);}//將共享內存映射到子進程
其中,shmid為shmget()函數的返回值,即共享內存標識碼。
從用戶的角度看,在父進程中可以對p_addr進行讀寫操作,實際訪問的是申請的共享內存。子進程則可以對c_addr進行讀寫,從而實現兩個進程間的通信。共享內存的映射和進程之間的關系,如圖4所示。
圖4 進程和共享內存映射關系
2.3 系統控制流程
在程序初始化完成后,為每項任務創建了相應的進程,并建立了共享內存,如圖5所示。在每個進程中采用循環執行方式,語音識別進程中利用select函數監控是否有識別結果輸出,并將識別結果寫入到相應的共享內存區。
圖5 系統控制流程圖
航向測量和計算進程循環讀取陀螺儀的角度信息并存儲。超聲波測距進程在接收到信息處理進程的控制命令后進行測距并將數據返回至信息處理進程。信息處理進程融合了多傳感器的數據,根據設定的路徑規劃方案,將控制信息傳輸到電機控制進程,實現機器人姿態的調整。
2.4 語音識別
在系統運行過程中,語音識別進程獨立完成對語音模塊的初始化和讀取識別結果的任務,因此,能夠及時響應操作人員發出的語音指令。程序中使用了select()函數監控read()是否可讀。當語音識別模塊LD3320有識別結果時,將在中斷引腳輸出高電平以觸發系統中斷,結束驅動程序中的等待狀態,同時應用程序可以通過read()函數讀取LD332O的識別結果,并寫入到相應共享內存區M中。在沒有中斷時,read()函數將被阻塞,如圖6所示。
圖6 語音識別進程流程圖
使用select機制監控是否語音識別結果,在超出等待時間后,會退出等待并重新初始化語音模塊LD3320,釋放公共資源,這樣也使得系統能夠及時響應LD332O的MP3播放功能,避免了在長時間沒有語音識別結果時,系統進入卡死狀態。
2.5 航向測量
為了使移動機器人能夠沿指定的方向行駛并能修正由外界干擾因素產生的航向偏差,系統采用陀螺儀航向測量模塊MPU - 6050,該模塊將其測量的模擬量轉換為可輸出的數字量,并通過串口發送到S3C2440.系統通過read(fd_uartl,bur,10)函數讀取相應串El,得到航向數據并寫人到共享內存區S中。
2.6 超聲波測距
本系統采用渡越時間法,超聲波測距模塊在收到發射控制信號時,換能器將發出40 kHz的連續脈沖信號。接收器的輸出高電平時間和距離成正比,同時觸發處理器的中斷,上升沿中斷開啟定時器,下降沿關閉定時器,利用處理器內部的定時器1測量出輸出信號的高電平的持續時間△T,經過式(1)的計算,可得到檢測距離S: S- V × △T/2 (1) 式中,V 為超聲波的傳播速度,常溫下超聲波在空氣中的傳播速度是340 m/s.程序中根據所編寫的驅動程序,使用ioctl(fd_chao,SEND_BEGIN)、ioctl(fd_chao,SEND_STOP)控制GPIO以實現超聲波的發射和停止。系統中對某個方向連續測量5次,進行中值濾波并將濾波后數據傳遞到信息處理進程。
2.7 電機控制
移動平臺中采用L298驅動直流減速電機,平臺尚未安裝速度反饋單元,簡化了控制模式。程序通過ioctl()控制L298以實現電機的正反轉以及停止操作。
在電機驅動程序中定義了相應GPIO的輸入/輸出方式:ioctl(fd,TURN_LEFT)中,fd為驅動程序的文件描述符;TURN_LEFT 是命令掩碼CMD,驅動程序根據命令掩碼CMD對相應的GPIO賦值以控制L298的狀態。
3 路徑規劃和避障算法
根據模糊邏輯法,移動平臺能夠在不確定環境中實現局部路徑規劃和避障。
3.1 輸入輸出變量的模糊化
在路徑規劃過程中,信息分析模塊的輸入量為移動平臺的行駛方向信息、與障礙物之間的相對位移信息;輸出量為移動平臺的旋轉角度和平動位移信息。
① 定義移動平臺與左側障礙物的距離為DL、與右側障礙物的距離為DR、前方障礙物的距離為DF.模糊子集定義為{S,M,B},分別表示小、中、大,相應的距離隸屬度函數如圖7所示。
圖7 距離隸屬度函數
② 定義移動平臺和目標點之間夾角為了,模糊子集定義為{LB,LS,Z,RS,RB},分別表示左大、左小、零、有小和右大。相應的角度隸屬度函數如圖8所示。
③ 移動平臺的旋轉角度φ的模糊子集定義為{TIB,TLS,TZ,TRS,TRB}。分別表示左轉大、左轉小、不旋轉、右轉小、右轉大,相應的輸出隸屬度函數如圖9所示。
3.2 建立模糊控制規則
在移動機器人遠離障礙物或不存在障礙物的情況下,依據移動平臺的行駛軌跡,可以先對行駛方向進行調整。當檢測到障礙物接近移動平臺時,移動平臺應改變行駛軌跡,避免發生碰撞。移動平臺的部分模糊控制規則如表1所列。
圖8 角度隸屬度函數
圖9 輸出隸屬度函數
表1 模糊控制規則
3.3 模糊推理和解模糊化
根據距離隸屬度函數,將超聲波測量得到的不同方位的距離數據轉換為模糊邏輯狀態,再查找模糊控制規則,查表得到相應的輸出模糊量。
解模糊化是輸出模糊量映射到動作行為的過程。模糊控制器對移動平臺的動作進行了分解并編碼,將復雜的動作分解為一系列簡單動作的疊加,使得每一個輸出模糊量對應一套動作。
例如在檢測到前方有障礙物并確定左轉時,可以將機器人動作分解為:后退(左轉,即先后退,再左轉。這樣可以減小機器人觸碰到前方障礙物的概率。
4 實驗測試
使用menuconfig命令為嵌入式Linux系統內核配置添加相應驅動程序后,進行make編譯生產zImage文件。啟動移動機器人系統并進入BIOS模式,將配置好的內核通過Supervivi工具燒寫到NAND Flash.在系統啟動后,配置Linux目錄中的/etc/init.d文件,使系統啟動后,自動運行所設計的程序。
如果系統初始化正常,將聽到由語音模塊發出的提示聲:“校準完成”。此時,操作人員可以下達“前進”、“后退”或“測距”等設計好的語音指令,機器人將按照操作人員的指令完成相應的動作,還可以通過語音模塊播放出測量到的距離。
結語
系統利用了Linux系統支持多任務和可裁剪的特點,結合處理器豐富的接口資源,實現了多方位超聲波測距、電機控制等功能,通過對多傳感器信息的融合和分析,為模糊邏輯法進行路徑規劃提供了判斷依據。語音識別功能使得機器人和操作人員之間的人機交互變得更靈活方便。在此基礎上,可以利用Linux操作系統強大的網絡功能,為進一步研究服務機器人、機器人聯網、機器人與機器人通信等提供了一種方案。
-
控制系統
+關注
關注
41文章
6604瀏覽量
110576 -
Linux
+關注
關注
87文章
11292瀏覽量
209330 -
移動機器人
+關注
關注
2文章
762瀏覽量
33564
發布評論請先 登錄
相關推薦
評論