0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

輪式移動機器人里程計分析

3D視覺工坊 ? 來源:混沌無形 ? 2023-04-19 10:17 ? 次閱讀

摘要:本文主要分析輪式移動機器人的通用里程計模型,并以兩輪差速驅動機器人的里程計計算為案例,給出簡化后的兩輪差速驅動機器人里程計模型。

01

引言

里程計是機器人導航系統(tǒng)中非常重要的一環(huán),那么何為里程計?

里程計,可簡單理解為記錄機器人在一段時間內的運動狀態(tài),是基于時間戳的數據幀,該數據幀包含機器人位置、姿態(tài)及運動速度、角速度,具體結構對應下圖 1.1。

961699bc-de57-11ed-bfe3-dac502259ad0.png

圖 1.1 ROS里程計數據結構

里程計的英文單詞是Odometry,在ROS小車坐標系樹里面有一個里程計專用坐標系,叫做Odom。

但凡涉及到可移動的機器人的導航系統(tǒng),大概率會涉及到里程計的計算,比如輪式移動機器人、無人機、無人艇,以及多足機器人等,而計算里程計的方案也有很多種,比如基于編碼器合成里程計的方案、基于視覺的里程計方案(ORB SLAM)、基于激光雷達的里程計方案(Hector SLAM)、基于IMU的里程計方案,以及多傳感器融合的方案。

本文主要以輪式移動機器人為載體介紹基于編碼器合成里程計的方案,這是非常經典常用的里程計計算方法之一,在輪式移動機器人領域有著廣泛的應用。

02

里程計模型分析

從圖 1.1可以看出,里程計主要包含的信息有兩部分:速度和位姿,因此接下來將從這兩個方面展開介紹。

2.1 速度計算

2.1.1 輪速計算

輪式機器人的驅動輪是由伺服電機驅動的,而電機轉軸后安裝有編碼器,通過編碼器采集的數據可以計算出電機輸出軸轉過的角度。

962b52b2-de57-11ed-bfe3-dac502259ad0.jpg

(a)編碼器結構

96357396-de57-11ed-bfe3-dac502259ad0.png

(b)編碼器輸出波形

圖 2.1 光電編碼器原理

編碼器的種類很多,比如增量式光電編碼器(圖 2.1),紅色的光源是固定不動的,當光柵(圖中灰色帶孔圓盤)轉動的同時,其電路結構會輸出A、B兩相的方波,使用單片機GPIO的中斷模式可采集到方波邊沿,進而進行計數,當電機軸轉動一圈,可獲取總計數為N(可能是512、也可能是1024,這與編碼器分辨率有關)。

假設編碼器在t1時刻的計數是n1,經過△t時間后,在t2時刻的計數是n2,因此可知電機轉軸在△t時間內轉過的角度△φ,表示為

那么角速度便可表示為

輪直徑是可以直接測量出來的,但需要校準(可參考《常見移動機器人輪直徑校準》),則可計算出驅動輪轉動的線速度v,可表示為

式中,dw為輪直徑。

這樣就可以將所有驅動輪的線速度計算出來,如果驅動輪與地面之間沒有相對滑動(也就是打滑),那么該線速度也就是驅動輪在地面上的運動線速度。

2.1.2 Odom速度計算

Odom坐標系一般與建立機器人運動學模型時的坐標系相同,也就是機器人零半徑轉彎的旋轉中心為坐標系原點,具體可參考《常見移動機器人運動學模型總結》。

需要注意的是,Odom是一個運動的坐標系,會隨著機器人的運動而運動,但是Odom記錄的是運動過程中的Odom坐標系狀態(tài)參數(速度、位姿)是在初始位姿的Odom的坐標系中描述的,如下圖所示:記錄的是Odom(tk)在Odom(t0)坐標系下的位姿和速度。

963b42ee-de57-11ed-bfe3-dac502259ad0.png

圖 2.2 差速驅動機器人運動及其軌跡

這里需要正運動學模型來計算Odom坐標系原點的運動速度,以兩輪差速驅動機器人為例,可表示為

9646fa62-de57-11ed-bfe3-dac502259ad0.png

圖 2.3 兩輪差速模型.機器人的外輪廓可視為圓形,直徑為dwb,ICR表示瞬時旋轉中心,藍色圓弧表示機器人運動路徑,點L和R分別為左右輪與地面的接觸點。

運動學模型寫為

其中,vr和vl分別表示兩驅動輪的線速度,是可以通過章節(jié)2.1.1中的方法計算出來的,因此幾何中心的線速度vc和角速度w就可以通過公式(4)計算出來。公式(4)中的vc也就是Odom坐標系x軸的線速度vx,由于兩輪差速驅動機器人的非完整性約束(具體分析可參考《兩輪差速驅動機器人運動模型及應用分析》),線速度vy和vz均為0,而公式(4)中的角速度w是Odom坐標系z軸的角速度wz,其余角速度wx和wy均為0。

從公式(4)中可以看出,除了前面提到的輪直徑需要校準之外,還需對輪間距dwb進行校準,由此實現

由此,圖 1.1中的的Odom結構體中的Twist子結構體可寫為

表 2?1 兩輪差速驅動機器人Twist信息

linear angular
x vc 0
y 0 0
z 0 w

以上是兩輪差速驅動機器人的速度計算思路,而麥輪移動平臺與之不同,屬于全向移動機器人,是包含3個自由度,對應的運動學模型也是不一樣的,寫為

9655772c-de57-11ed-bfe3-dac502259ad0.png

圖 2.4 麥輪平臺運動分解示意圖. 圖中r表示中心點CENTER到麥輪與地面接觸點之間的距離,rx和ry分別表示r在CENTER坐標系x軸和y軸上的投影距離(均為正值).

采用同樣的思路,計算出四個驅動輪的線速度,結合公式(5)便可得到麥輪平臺中心的速度信息。

由此,圖 1.1中的的Odom結構體中的Twist子結構體可寫為

表 2?2 麥輪移動平臺Twist信息

linear angular
x vcx 0
y vcy 0
z 0 wc

除了兩輪差速驅動機器人和麥輪移動平臺,均可以通過上述思路計算得到里程計中的Twist信息。

2.2 位姿計算

計算Odom的位姿是依賴于章節(jié)2.1.2中的速度信息的,我們知道速度對時間積分就是位移,角速度對時間積分就是轉角。而里程計記錄的是機器人在某一時間段內的運動軌跡,也就是位姿變換過程(如圖 2.2所示),需要用遞推方程表示,如果是兩輪差速驅動機器人,寫為:

式中,[x y θ]分別表示兩輪差速驅動機器人在某時刻的位置和姿態(tài)角

965eafe0-de57-11ed-bfe3-dac502259ad0.png

圖 2.5 兩輪差速驅動機器人運動過程. 藍色弧線表示運動軌跡

結合圖 2.5來解釋公式(6),從公式(6)可以看出是做了近似處理,包括:dt時間內假設機器人是以[vc w]的速度進行勻速運動,但實際速度肯定不是勻速運動的,這存在誤差;另外,驅動輪可能存在微弱打滑的情況,也會引入誤差;最后,兩輪差速驅動機器人運動軌跡是圓弧曲線,速度方向是沿著圓弧切線方向的變化而變化的,但這里假設dt時間間隔很短,故“以直代曲”,認為機器人運動軌跡是直線段、速度方向也是不變的,在dt時間內保持著θ的方向,所以也會引入誤差。

如果是麥輪移動平臺,原理也是和兩輪差速驅動機器人一致的,但又有些區(qū)別:麥輪平臺多了一個自由度,但可以從速度分解(或運動合成)的角度分析

化簡為

麥輪移動平臺公式也包含了兩輪差速驅動機器人的近似處理思想。

綜合上述分析,可以計算得到t時刻下機器人的運動速度、位姿信息,合在一起也就是里程計信息了。

03

案例分析

從前面的分析可以看出,在計算速度、位姿時,經過多次運算,位姿計算精度有所降低,此外,計算速度和位姿時,都需要一個時間間隔dt,那么可以從這個dt入手,進一步化簡,得到更簡潔、優(yōu)雅的公式。

這里以兩輪差速機器人為例,計算化簡里程計公式。

假設差速機器人在極短的dt時間內運動了一小節(jié)距離,故可視為在dt時間內機器人做勻速運動,如圖 3.1所示,在極短時間內做勻速運動,可寫為

9677c444-de57-11ed-bfe3-dac502259ad0.png

圖 3.1 差速驅動機器人里程計示意圖

如果機器人做勻速運動,且存在角速度,那么機器人中心的運動軌跡一定是一段標準的圓弧,其長度表示為△Sc,對應的圓心角為△θ,因此有下面的這個關系式

則,左輪和右輪的運動軌跡長度可寫為

結合公式(8)和(9),有

為后續(xù)計算,這里需要對公式(6)做一個修正,細心的讀者可能已經發(fā)現問題了,在公式(6)中,方向角使用的是θt,也就是速度vct的方向,這個方向和△dc的方向之間存在一個夾角,這個夾角的大小是△θ/2,使用△dc的方向比速度vct的方向更加準確,因此修正后的公式(6)為

可見,這里還存在一個系統(tǒng)誤差,也就是圓弧長度△Sc和直線段長度△dc并不相等,要得到直線段長度△dc,還需要再做一個轉換(三角變換,也可以使用余弦定理)

需要回顧的是,這里有個假設,dt時間間隔極短,意味著△θ非常小,所以公式(12)可寫作

從公式(13)可以看出,兜兜轉轉,又回到了公式(8),這里就需要做一個權衡,如果dt時間間隔極短,那么可以取近似值,也就是認為△dc≈△Sc,以直代曲,如果dt時間間隔偏長,那么可以采用公式(12)計算,計算中包含正弦函數,但會降低計算效率、損失計算精度。

這里就采用“以直代曲”的方式來做進一步計算:

通過公式(9)計算△θ,得

將公式(10)和公式(15)帶入公式(14),可知

因此,可狀態(tài)轉換方程可寫作

從公式(17)可知,僅需要計算左右驅動輪在dt時間內運動過路程,便可得到dt時刻的位姿,回顧到本文的章節(jié)2.1.1的輪速計算,根據公式(1)可以計算驅動輪轉過的角度,因此可以得到運動的路程

式中,nl1、nl2分辨表示左輪在時間dt前后采集的左輪編碼器讀數,nr1、nr2分辨表示右輪在時間dt前后采集的右輪編碼器讀數。

所以,將公式(17)和(18)相結合,僅需要定期采集編碼器讀數,即可更新里程計中的位姿信息,而速度信息也是可以根據公式(2)和(3),結合運動學模型計算出來。而在實際應用中,編碼器采集頻率和里程計更新頻率保持一致(或整數倍),這樣更利于計算,減少重復計算帶來的精度損失和時間消耗。

從前面的公式可以看出,要得到更準確的里程計參數,需要對差速驅動機器人的輪直徑和輪間距進行校準。

其他的機器人里程計模型也可以參考兩輪差速驅動機器人案例,做進一步化簡,減少重復計算。

04

結論及展望

本文主要從編碼器原理介紹、輪速計算及位姿計算等方面分析了輪式移動機器人的通用里程計模型,并以兩輪差速驅動機器人的里程計計算為案例,詳細分析了兩輪差速驅動機器人運動規(guī)律及其位姿變換的等效思想,最后給出了簡化后的兩輪差速驅動機器人里程計模型。

審核編輯 :李倩

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 機器人
    +關注

    關注

    210

    文章

    27838

    瀏覽量

    204571
  • 編碼器
    +關注

    關注

    44

    文章

    3529

    瀏覽量

    133267
  • 導航系統(tǒng)

    關注

    2

    文章

    251

    瀏覽量

    30543
收藏 人收藏

    評論

    相關推薦

    資料:移動機器人能否自動充電?

    、餐飲服務行業(yè)已經應用到了機器人。不過目前,移動機器人都是使用高質量的機載可充電蓄電池組來給自身供電,但是一般只能維持幾個小時,一旦電能耗盡,必須采用人工干預的方式來給機器人充電。如果采用人工充電,那么
    發(fā)表于 01-20 09:39

    Labview My RIO 移動機器人

    初次使用 NI MyRIO控制器開發(fā)四輪全向移動機器人,由四個全向輪和直流電機與增量式編碼器和NI 9001控制器組成,安裝了紅外距離和光電傳感器。驅動板由官方提供的H橋驅動板。NI 9001由
    發(fā)表于 08-21 12:20

    機器人、協(xié)作機器人移動機器人,你分的清楚嗎

    我覺得現在是時候討論一些更有趣的話題,今天的話題是介紹工業(yè)機器人、協(xié)作機器人移動機器人。我想每個人都知道機器人是什么。機器人是可怕的大型
    發(fā)表于 10-30 11:33

    基于LPC2119的自主式移動機器人設計方案

    了一種輪式移動機器人的設計方案。該機器人系統(tǒng)應用超聲傳感器、光敏傳感器、碰撞傳感器采集外部環(huán)境信息,采用PTR2000實現移動機器人與計算機通信,從而實現現場信息的反饋和計算機控制命令
    發(fā)表于 05-11 06:39

    有哪些廠家的輪式移動機器人可以實現力矩控制?

    小白,剛入行,想請教一下各位大佬,pioneer 3-AT可以使用力矩進行控制嗎?如果不行的話,哪些廠家的輪式移動機器人是開放力矩控制的?
    發(fā)表于 09-22 11:00

    如何實現移動機器人的設計?

     移動機器人利用導航技術,獲得機器人的目前所處的位置,結合傳感器技術對周圍外界環(huán)境(障礙物等)作實時探測,并根據環(huán)境提供的信息規(guī)劃一條可行路徑完成達到目標點的任務。移動機器人技術涉及到傳感器技術
    發(fā)表于 11-23 15:08

    什么是移動機器人軟硬件系統(tǒng)問題

    接觸了移動機器人這么久,我覺得應該寫點什么東西,分享一下最基礎的自己關于移動機器人的理解,也作為筆記總結,留到以后查閱。目前我還是覺得自己剛入門,有時候總想的太多,不如實踐來的更直接,下面總結之前
    發(fā)表于 08-06 06:13

    差速移動機器人軌跡跟蹤控制方法

    步驟五、仿真實驗比較1、基于PID的差分移動機器人軌跡跟蹤仿真(1)不同參數下的仿真對比以確定最優(yōu)參數(2)仿真分析
    發(fā)表于 09-01 08:41

    基于車體加速度反饋的輪式移動機器人軌跡跟蹤控制研究

    本文分析輪式移動機器人在運行過程中由于動力學不確定性引起的力矩擾動, 并提出了一種基于傳感器的移動機器人控制方法. 在利用線加速度傳感器實時測量
    發(fā)表于 07-17 08:08 ?32次下載

    基于模糊PID的輪式移動機器人軌跡控制

    本文針對實際的輪式自主移動機器人軌跡控制和定位問題提出了一種解決方法。利用模糊PID復合控制器實現移動機器人的軌跡控制,利用陀螺、磁羅盤、里程計進行多傳感器融合定位
    發(fā)表于 07-17 10:14 ?24次下載

    基于全景視覺與里程計移動機器人自定位方法

    通過分析全景視覺與里程計傳感器的感知模型的不確定性,提出了一種基于路標觀測的 移動機器人 自定位算法. 該算法利用卡爾曼濾波器,融合多種傳感器在不同觀測點獲取的觀測數據完
    發(fā)表于 06-28 10:58 ?41次下載
    基于全景視覺與<b class='flag-5'>里程計</b>的<b class='flag-5'>移動機器人</b>自定位方法

    輪式移動機器人WMR的運動分析

    研究了輪式 移動機器人 (WMR ) 的運動問題, 分析了一種理想滾動情況下航向角控制的差動運動模型. 通過算例證明該方法簡單實用, 在輪式移動機器
    發(fā)表于 06-28 11:07 ?33次下載
    <b class='flag-5'>輪式</b><b class='flag-5'>移動機器人</b>WMR的運動<b class='flag-5'>分析</b>

    移動機器人的分類與移動機器人技術研究現狀和未來發(fā)展的分析

    移動機器人分類 移動機器人從工作環(huán)境來分0可分為室內移動機器人和室外移動機器人1按移動方式來分!輪式
    發(fā)表于 09-16 09:18 ?13次下載

    如何使用模糊PID的輪式移動機器人進行軌跡控制

    本文針對實際的輪式自主移動機器人軌跡控制和定位問題提出了一種解決方法。利用模糊PID復合控制器實現移動機器人的軌跡控制,利用陀螺、磁羅盤、里程計進行多傳感器融合定位。在計算機仿真和實際
    發(fā)表于 06-19 17:37 ?35次下載
    如何使用模糊PID的<b class='flag-5'>輪式</b><b class='flag-5'>移動機器人</b>進行軌跡控制

    介紹一種基于編碼器合成里程計的方案

    摘要:本文主要分析輪式移動機器人的通用里程計模型,并以兩輪差速驅動機器人里程計計算為案例,給出
    的頭像 發(fā)表于 04-19 10:16 ?1851次閱讀