本發(fā)明涉及一種基于webrtc的機器人遙操作系統(tǒng),屬于機器人領域。
背景技術:
遙操作是一個古老的話題,自從提出至今對它的研究就一直沒有間斷。隨著科學和時代的發(fā)展,機器人遙操作在諸如太空、深海探測,遠程的病房監(jiān)控等領域內(nèi),都發(fā)揮著不可替代的作用。借助于internet資源的諸多便利條件,人們對網(wǎng)絡機器人的需求必然會日益擴大。而新興的html5技術,又給網(wǎng)絡機器人的遙操作開辟了一個新的發(fā)展方向。
webrtc是一項基于html5的在瀏覽器內(nèi)部進行實時的音視頻通訊的技術。實現(xiàn)了基于網(wǎng)頁的視頻會議,只通過瀏覽器內(nèi)部進行javascript就可以達到實時通訊的能力,而且不需要瀏覽器提供任何形式的插件。webrtc提供了視頻會議的核心技術,包括音視頻的采集、編解碼、傳輸和顯示,而且還支持跨平臺的調(diào)用。
當前存在的網(wǎng)絡機器人遙操作系統(tǒng)設計是多種多樣的,各生產(chǎn)廠家分別用自己的手段和方法來實現(xiàn)控制信號和音視頻信號的傳輸。音視頻信號有些使用了第三方的開源軟件,如skype;有些使用了自己定制的音視頻傳輸軟件;有些使用了flash等音視頻的傳輸工具。而對于控制信號一般使用socket或xmlsocket;或者自己定制遙操作控制軟件。這些遙操作系統(tǒng)的主要問題在于需要先在客戶端安裝控制軟件或者瀏覽器插件,不能實現(xiàn)跨平臺訪問,而且也不能實現(xiàn)機器人運動狀態(tài)變量對流媒體信號的調(diào)節(jié)。otorob考慮了機器人的所處場景,根據(jù)場景和機器人的速度來調(diào)節(jié)視頻流的參數(shù),來達到節(jié)省帶寬的目的;drrobotx80則是考慮了機器人的傳感器信息,將障礙物作為機器人運動時的感興趣信息,當檢測到障礙物時增大視頻流的幀率,以達到保證用戶體驗性的目的;pr2則利用ros平臺搭建遙操作系統(tǒng),用websocket傳遞控制信號,使用mjpegserver搭建流媒體服務器,客戶端使用html插件來實現(xiàn)。上述所說遙操作系統(tǒng),增加了機器人的狀態(tài)變量對流媒體傳輸?shù)目刂?,達到了良好的效果,但是問題依然是對客戶端要求過高,而且沒有考慮網(wǎng)絡狀況。pr2雖然基于html5技術開發(fā),但是其流媒體傳輸編碼效率較低,而且本身也需要插件的支持。
技術實現(xiàn)要素:
本發(fā)明提供一種基于webrtc的機器人遙操作系統(tǒng),不僅客戶端能夠在瀏覽器內(nèi)與機器人進行音視頻交互,而且利用webrtc開源代碼開源出分辨率和幀率的接口,用于通過云臺相機的轉(zhuǎn)角位置、距離傳感器的感知信息和機器人的速度控制機器人端的視頻流分辨率和幀率。
本發(fā)明解決其技術問題所采用的技術方案是:
一種基于webrtc的機器人遙操作系統(tǒng),包括機器人、客戶端和nodejs服務器,機器人頭部安裝有云臺相機,通過二自由度轉(zhuǎn)動獲取環(huán)境視頻信號,機器人上安裝有麥克風,用于獲取環(huán)境的音頻信號,機器人周圍裝有距離傳感器,用于探測距離機器人較近障礙物的信息,機器人的頂部安裝有顯示器和音箱,用于呈現(xiàn)遙操作者的音視頻信號,機器人底部安裝在移動平臺上;客戶端使用支持webrtc功能的瀏覽器向機器人發(fā)出控制指令和音視頻信號,同時接收機器人發(fā)送的控制指令和音視頻信號;nodejs服務器分別向機器人、客戶端完成音視頻流報文的互換和轉(zhuǎn)發(fā);
作為本發(fā)明的進一步優(yōu)選,控制指令的傳輸遵循websocket協(xié)議,包括控制移動平臺的運動指令和控制云臺相機轉(zhuǎn)角運動的指令;
作為本發(fā)明的進一步優(yōu)選,客戶端用支持webrtc功能的瀏覽器,通過javascript調(diào)用實現(xiàn)與機器人的實時音視頻傳輸,機器人用webrtc的開源代碼,并開源出分辨率和幀率的參數(shù),音視頻傳輸前首先完成兩端初始化報文的傳輸,兩端在添加完sdp消息響應后向nodejs服務器傳輸基于websocket的sdp消息,描述本端地址和端口信息,nodejs服務器完成報文的互換和轉(zhuǎn)發(fā),一旦對端的報文到達便進行webrtc的音視頻點對點傳輸;
作為本發(fā)明的進一步優(yōu)選,客戶端遙操作指令包括云臺相機轉(zhuǎn)角的運動指令和移動平臺的運動指令,客戶端控制云臺相機的轉(zhuǎn)角和底部移動平臺的運動速度,機器人周圍的距離傳感器實時檢測距離機器人障礙物的信息;機器人視頻的分辨率根據(jù)云臺相機轉(zhuǎn)角位置、距離傳感器的信息和機器人運動速度進行調(diào)節(jié)。
通過以上技術方案,相對于現(xiàn)有技術,本發(fā)明具有以下有益效果:
本發(fā)明提出了一種基于webrtc的機器人遙操作系統(tǒng),該系統(tǒng)客戶端的瀏覽器內(nèi)部進行與機器人端進行音視頻交互,機器人端不僅利用webrtc的開源代碼與客戶端傳輸音視頻,還在webrtc的開源代碼上封裝了上層調(diào)用,通過云臺相機的轉(zhuǎn)角位置,距離傳感器的感知信息和機器人的運動速度調(diào)節(jié)機器人端的流媒體傳輸分辨率和幀率。
附圖說明
下面結(jié)合附圖和實施例對本發(fā)明進一步說明。
圖1是本發(fā)明的優(yōu)選實施例的硬件結(jié)構(gòu)圖;
圖2是本發(fā)明的優(yōu)選實施例的webrtc傳輸算法流程圖;
圖3是本發(fā)明的優(yōu)選實施例的移動平臺的流媒體傳輸方法流程圖。
具體實施方式
現(xiàn)在結(jié)合附圖對本發(fā)明作進一步詳細的說明。這些附圖均為簡化的示意圖,僅以示意方式說明本發(fā)明的基本結(jié)構(gòu),因此其僅顯示與本發(fā)明有關的構(gòu)成。
如圖1所示,本發(fā)明的一種基于webrtc的機器人遙操作系統(tǒng),包括機器人、客戶端和nodejs服務器,機器人頭部安裝有云臺相機,通過二自由度轉(zhuǎn)動獲取環(huán)境視頻信號,機器人上安裝有麥克風,用于獲取環(huán)境的音頻信號,機器人周圍裝有距離傳感器,用于探測距離機器人較近障礙物的信息,機器人的頂部安裝有顯示器和音箱,用于呈現(xiàn)遙操作者的音視頻信號,機器人底部安裝在移動平臺上;客戶端使用支持webrtc功能的瀏覽器向機器人發(fā)出控制指令和音視頻信號,同時接收機器人發(fā)送的控制指令和音視頻信號;nodejs服務器分別向機器人、客戶端完成音視頻流報文的互換和轉(zhuǎn)發(fā);
作為本發(fā)明的進一步優(yōu)選,控制指令的傳輸遵循websocket協(xié)議,包括控制移動平臺的運動指令和控制云臺相機轉(zhuǎn)角運動的指令;
作為本發(fā)明的進一步優(yōu)選,客戶端用支持webrtc功能的瀏覽器,通過javascript調(diào)用實現(xiàn)與機器人的實時音視頻傳輸,機器人用webrtc的開源代碼,并開源出分辨率和幀率的參數(shù),音視頻傳輸前首先完成兩端初始化報文的傳輸,兩端在添加完sdp消息響應后向nodejs服務器傳輸基于websocket的sdp消息,描述本端地址和端口信息,nodejs服務器完成報文的互換和轉(zhuǎn)發(fā),一旦對端的報文到達便進行webrtc的音視頻點對點傳輸;
作為本發(fā)明的進一步優(yōu)選,客戶端遙操作指令包括云臺相機轉(zhuǎn)角的運動指令和移動平臺的運動指令,客戶端控制云臺相機的轉(zhuǎn)角和底部移動平臺的運動速度,機器人周圍的距離傳感器實時檢測距離機器人障礙物的信息;機器人視頻的分辨率根據(jù)云臺相機轉(zhuǎn)角位置、距離傳感器的信息和機器人運動速度進行調(diào)節(jié);若檢測到障礙物在云臺相機的視野范圍內(nèi),則提高機器人端視頻流的分辨率和幀率;反之則保持預先設定的分辨率和幀率進行傳輸。另外,機器人端視頻流的分辨率根據(jù)移動平臺速度進行調(diào)節(jié),并且在一定范圍內(nèi)速度越大、分辨率越高。
如圖2所示,是webrtc傳輸算法流程圖,對于客戶端和服務器的webrtc程序,主要由以下幾步調(diào)用組成:
(1)捕獲本地的音視頻流;一路回送給本地顯示,一路用于rtp傳輸;
(2)設置視頻流的分辨率和幀率;這步在機器人端peerconnection完成,將peerconnection中決定視頻分辨率和幀率的函數(shù)調(diào)用提取出來,用于構(gòu)造流媒體參數(shù)調(diào)節(jié)算法的接口,調(diào)節(jié)機器人端視頻流的分辨率和幀率;
(3)添加sdp消息響應;為了傳輸webrtc流媒體的報文,需要構(gòu)造基于websocket的sdp消息,用于描述本次的會話名、帶寬信息、媒體類型、傳輸協(xié)議、媒體格式、端口和地址等方面的內(nèi)容,并設置本端的消息響應機制。該報文用于流媒體傳輸?shù)某跏蓟?。一旦?gòu)造好sdp消息就向nodejs服務器發(fā)送。nodejs服務器完成消息的轉(zhuǎn)發(fā),并且完成傳輸情況的監(jiān)聽;
(4)使用websocket將構(gòu)造好的sdp消息傳輸?shù)綄Χ耍?/p>
(5)兩端接收到sdp消息后執(zhí)行相應的消息處理,并按照消息中的對端端口和地址傳輸捕捉到的音視頻流。
如圖3所示為移動平臺的流媒體傳輸方法流程圖,由云臺相機的轉(zhuǎn)角位置(設該方向距離機器人正前方偏轉(zhuǎn)d度)和機器人距離傳感器的信息可知在距離傳感器的感知范圍內(nèi)是否存在障礙物,以及該障礙物是否在機器人云臺相機的視野范圍內(nèi)(d-δ,d+δ),若在該角度范圍內(nèi)存在障礙物,則按照下式調(diào)節(jié)視頻流的分辨率和幀率:
其中,video.interval為視頻流兩幀之間的時間差,反映出幀率信息,f1>f2>f3。dis(s,p)為根據(jù)云臺相機的位置p和傳感器的信息s確定的在云臺相機的視野范圍內(nèi)(d-δ,d+δ)障礙物距離機器人的距離。
同時,速度檢測模塊實時檢測機器人當前運行的線速度和角速度,考慮到機器人運動時遙操作者對視頻流的清晰度感知不明顯,為了降低運動場景的網(wǎng)絡帶寬,確定如下機器人發(fā)送端的視頻分辨率決定公式:
其中,v為機器人運行的線速度,w為機器人運行的角速度。
若機器人存在速度,同時障礙物也存在與云臺相機的視野范圍內(nèi),則最終機器人端發(fā)送的視頻流的分辨率和幀率按照兩種方式的加權可得:
video.width=f(v,w,s,p)=m*video.height=m*g(v,w,s,p)=u*video.widthl+v*video.widthvvideo.interval=k(s,p)=video.intervall
其中,u,v分別為傳感器標定系數(shù)和速度標定系數(shù)。
本技術領域技術人員可以理解,除非另外定義,這里使用的所有術語(包括技術術語和科學術語)具有與本申請所屬領域中的普通技術人員的一般理解相同的意義。還應該理解的是,諸如通用字典中定義的那些術語應該被理解為具有與現(xiàn)有技術的上下文中的意義一致的意義,并且除非像這里一樣定義,不會用理想化或過于正式的含義來解釋。
本申請中所述的“和/或”的含義指的是各自單獨存在或兩者同時存在的情況均包括在內(nèi)。
本申請中所述的“連接”的含義可以是部件之間的直接連接也可以是部件間通過其它部件的間接連接。
以上述依據(jù)本發(fā)明的理想實施例為啟示,通過上述的說明內(nèi)容,相關工作人員完全可以在不偏離本項發(fā)明技術思想的范圍內(nèi),進行多樣的變更以及修改。本項發(fā)明的技術性范圍并不局限于說明書上的內(nèi)容,必須要根據(jù)權利要求范圍來確定其技術性范圍。