中正平和的機器人學筆記——6. 一種氣驅型柔性臂的正運動學模型

1. 前言

柔性臂是當前機器人領域一個比較熱的研究方向,國內外高校如MIT、Stanford、JHU和我校、上交、中科大、北航等等都有做研究。大致可以分爲三類:氣驅/繩驅,超彈性材料,智能材料(DE/EAP/SMA)。大多也集中在仿生方面的研究,比如象鼻型、章魚臂型等等,屬於機械/生物/計算機/電子/控制(強行加上我們控制)的交叉領域。
這周主要學習了Clemson University早年研究的一種氣驅型柔性臂。基本上白天看論文,晚上動手自己做硅膠構件,儼然和控制越來越遠。。。。。。

2. 模型分類

建立這類氣驅型柔性臂的模型具有一定複雜性,因爲要完整精確地描述橫向/縱向肌肉的運動和相互影響的機理,不過這論文都是十多年前的了,現在嘛。。。。。。

2.1 Complex, fully soft model

完整地描述肌纖維的運動及對其他肌纖維的影響,理想。。理想。。。一種oft model是把章魚臂看作一系列定容圓柱,每個圓柱能變直徑變長度;另一種是看作一系列的腔管,能在兩個方向上彎曲。
雖然這類模型在解釋運動機理上很好,但是soft model的主要問題:是難以用於控制柔性臂到達期待位姿,以及難以再現完全柔軟而定容的執行器。

2.2 Cylindrical extension model

把整個柔性臂分解成一系列變直徑的部分首尾連接起來。這種模型描述運動機理效果比較好。具體地說,也是看作一系列定容圓柱,通過對生物肌肉實際測量得到一些參數,能夠很好地預測章魚臂在一次捕食行爲中肌肉的動作,但是這種模型,按照原文說,主要描述了單關節臂杆的行爲,而不是整個完整機械臂的功能。(有一點點懵逼,論文也沒細講)

2.3 Circular curvature model

在一定的假設條件下,能更好地闡述章魚臂的運動機理,也是實際應用最多的一種。假設機械臂以恆定曲率彎曲且不能扭轉(這假設下當然更容易分析了。。)當然好處也很明顯,可以化簡爲一系列旋轉關節和位移關節,直接用DH參數法,經典的機器人控制理論和算法也可以套用。Clemson University的Elephant Trunk manipulator和Air-Octor single manipulator的分析都是基於這種模型。
圖1.Elephant Trunk manipulator
圖2. Air-Octor single manipulator
接下來分析這個Air-Octor single manipulator的正運動學模型。

3. 正運動學模型

3.1 整體分析

這個柔性臂由中間的軟管和外部保護軟管以及三個驅動的繩索組成。然後三個彎曲自由度,一個收縮自由度,也就是四自由度的柔性臂。
在這裏插入圖片描述
在這裏插入圖片描述
正運動學模型就是已知三個繩索的長度l1l_1l2l_2l3l_3,求解彎曲的角度 ϕ\phi 和曲率 kϕk_{\phi} 以及彎曲部分長度 ss。論文提供的算法分兩部分,先求解定義的一個長度 rir_i,再求出 ϕ\phikϕk_{\phi} 以及 ss

3.2 求解 rir_i

在這裏插入圖片描述
考慮上圖這一段柔性臂,通過繩索1的這一點給出一個垂直於繩索2和繩索3的平面。由這個平面就得到三個用於求解 rir_i 的中間變量:
h1=0h_1 = 0 (平面在繩索1那個點定義的,所以是0)
h2=l2l12nh_2 = \cfrac{l_2 - l_1}{2n}
h3=l3l12nh_3 = \cfrac{l_3 - l_1}{2n}
n是把整個柔性臂等分的段數。
在這裏插入圖片描述
得到了h1h_1h2h_2h3h_3後,接下來求 hch_c,也就是柔性臂截面的三個繩索構成的等邊三角形中點距離設定平面的距離。由上圖可以看出, hch_ch2mh_{2m}h3mh_{3m} 的平均值。那麼 h2mh_{2m}h3mh_{3m} 怎麼求解呢?
在這裏插入圖片描述
參考上圖,根據相似三角形的幾何關係就可以求出
h2m=l2l13nh_{2m} = \cfrac{l_2 - l_1}{3n}
h3m=l3l13nh_{3m} = \cfrac{l_3 - l_1}{3n}
相應地就可以求出hch_c
hc=l3+l22l16nh_{c} = \cfrac{l_3 +l_2 - 2l_1}{6n}
接下來我們再看下圖
在這裏插入圖片描述
上圖完整地描述了這一段彎曲的柔性臂的情況,根據描紅的一部分,我們可以得到如下等腰三角形
在這裏插入圖片描述
dhc=r1hc+l12n\cfrac{d}{h_c} = \cfrac{r_1}{h_c + \cfrac{l_1}{2n}}

這樣就可以推出r1:

r1=d(l1+l2+l3)l3+l22l1r_1 = \cfrac{d(l_1 + l_2 + l_3)}{l_3 + l_2 - 2l_1}

那麼r2r_2r3r_3 呢?論文直接給出結果了,不過還是希望大家自己能推導一下。
這是我自己推導畫的圖,手殘輕噴。要注意的是三根繩索長度不同,這個斜的截面它不是設定平面直接繞繩索1那個點所在的橫直線直接旋轉可以得到的,是一個。。有點彆扭的狀態,可以想象一下。
在這裏插入圖片描述
由上圖易得。。真的是容易得到,如果你認真分析了的話(滑稽):

dr2=hch2l12n+hc\cfrac{d}{r_2} = \cfrac{h_c - h_2}{\cfrac{l_1}{2n} + h_c}

dr3=h3hcl12n+hc\cfrac{d}{r_3} = \cfrac{h_3 - h_c}{\cfrac{l_1}{2n} + h_c}

整理後可得

r2=d(l1+l2+l3)l3+l12l2r_2 = \cfrac{d(l_1 + l_2 + l_3)}{l_3 + l_1 - 2l_2}

r3=d(l1+l2+l3)l1+l22l3r_3 = \cfrac{d(l_1 + l_2 + l_3)}{l_1 + l_2 - 2l_3}

3.3 求解 ϕ\phikϕk_{\phi}

r1r_1r2r_2r3r_3看作向量形式的話:
r1=r190ο\mathrm{r_1} = r_1\angle{90^\omicron}
r2=r2210ο\mathrm{r_2} = r_2\angle{210^\omicron}
r3=r330ο\mathrm{r_3} = r_3\angle{-30^\omicron}
具體如下圖
在這裏插入圖片描述
我們用一個基變換矩陣 BB 來求得正交基 ryr_yryr_y

B=[cos(210ο)sin(210ο)cos(30ο)sin(30ο)]B = \begin{bmatrix} \cos{(210^\omicron)} & \sin{(210^\omicron)} \\ \cos{({-30}^\omicron)} & \sin{({-30}^\omicron)} \\ \end{bmatrix}

rx=r3r23r_x = \cfrac{r_3 - r_2}{\sqrt{3}}

ry=r2r3r_y = -r_2 -r_3

然後我們就可以得到 (其實這部分不明白爲什麼這樣就得到了 ϕ\phi,希望有看到的朋友能幫忙解釋一下)

ϕ=tan1(ryrx)\phi = \tan^{-1}\left(\cfrac{r_y}{r_x}\right)

rϕ=rx2+ry2r_\phi = \sqrt{{r_x}^2 + {r_y}^2} (注意曲率 kϕ=1rϕk_\phi = \cfrac{1}{r_\phi}

最後整理消除中間變量得到

kϕ=2l12+l22+l32l1l2l2l3l1l1d(l1+l2+l3)k_\phi = 2\cfrac{\sqrt{{l_1}^2 + {l_2}^2 + {l_3}^2 -l_1l_2 - l_2l_3 -l_1l_1}}{d\left(l_1 + l_2 + l_3\right)}

ϕ=tan1(33l3+l22l1l2l3)\phi = \tan^{-1}\left(\cfrac{\sqrt3}{3}\cfrac{l_3 + l_2 - 2l_1}{l_2 - l_3}\right)

3.4 求解 ss

最後我們再求出柔性臂的長度,因爲前面我們是分成了n份來分析的。
根據前面的分析我們可以得到

lc=l1+l2+l33l_c = \cfrac{l_1 + l_2 + l_3}{3}
在這裏插入圖片描述
再根據上圖可以得到關係式如下:

sinβ2=lc2n1kϕ\sin\cfrac{\beta}{2} = \cfrac{\cfrac{l_c}{2n}}{\cfrac{1}{k_\phi}}

解得

s=2nkϕsin1(lckϕ2n)s = \cfrac{2n}{k_\phi}\sin^{-1}\left(\cfrac{l_ck_\phi}{2n}\right)

最後整理消除中間變量得

s=nd(l1+l2+l3)l12+l22+l32l1l2l2l3l1l3sin1(l12+l22+l32l1l2l2l3l1l33nd)s = \cfrac{nd(l_1 + l_2 + l_3)}{\sqrt{{l_1}^2 +{l_2}^2 + {l_3}^2 - l_1l_2 - l_2l_3 - l_1l_3}} \cdot \sin^{-1}\left( \cfrac{\sqrt{{l_1}^2 +{l_2}^2 + {l_3}^2 - l_1l_2 - l_2l_3 - l_1l_3}}{3nd}\right)

3.5 歸納整理

定義 g:=l12+l22+l32l1l2l2l3l1l3g := {l_1}^2 +{l_2}^2 + {l_3}^2 - l_1l_2 - l_2l_3 - l_1l_3,則z正運動學模型可歸納爲

kϕ=2gd(l1+l2+l3)k_\phi = 2\cfrac{\sqrt g}{d(l_1 + l_2 + l_3)}

ϕ=tan1(33l3+l22l1l2l3)\phi = \tan^{-1}\left(\cfrac{\sqrt3}{3}\cfrac{l_3 + l_2 - 2l_1}{l_2 - l_3}\right)

s=nd(l1+l2+l3)gsin1(g3nd)s = \cfrac{nd(l_1 + l_2 + l_3)}{\sqrt g} \cdot \sin^{-1}\left( \cfrac{\sqrt g}{3nd}\right)

注意上式中limg0s=l1+l2+l33\lim\limits_{g \to 0}s = \cfrac{l_1 + l_2 + l_3}{3}

4. 總結

以上就是一種氣驅型柔性臂的z正運動學推導,其實可以看到所運用到的數學工具除了基變換矩陣那裏以外,其他的基本上就是高中幾何代數就可以解決的……所以說有些東西乍一看上去彷彿很艱深晦澀,可是鑽研進去就會發現其實也並不很難,甚至還有點意思。另外一點收穫就是看論文的時候很容易看人家推導順着思路就覺得,哦,對,就這麼推,很簡單,就好比做題的時候看着參考答案自然覺得很簡單,但是合上答案自己做題就發現不是那麼一回事,所以看論文想要消化作者的精髓,自己推導公式是必不可少的,再一點就是要反覆讀啦。

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