新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 基于STM32的智能物流機器人

基于STM32的智能物流機器人

作者:黃學達,楊俊杰,侯志鵬,黃俞霖,章世博(重慶郵電大學自動化學院,重慶 400065) 時間:2023-04-26 來源:電子產(chǎn)品世界 收藏
編者按:設計了以STM32F103C8T6芯片為主控的智能物流機器人,并對機器人系統(tǒng)性能進行分析。電機調速動態(tài)指標中調節(jié)時間平均為560 ms,超調量平均34.6%。隨著電機轉速增大,調節(jié)時間呈減小趨勢。機械臂跟蹤性能在PID控制下表現(xiàn)良好,平均每2.5 s完成跟蹤目標并準確抓取,實物系統(tǒng)有良好的穩(wěn)定性、可靠性和準確性。

搬運機器人可代替人工在高溫、高壓、多粉塵等危險環(huán)境中作業(yè),節(jié)省大量人力資源,大幅提高工作效率。在未來智慧工廠建設中,智能物流搬運機器人技術起著舉足輕重的作用[1]。

本文引用地址:http://2s4d.com/article/202304/446017.htm

鑒于智能物流搬運機器人將來在制造業(yè)發(fā)展中勢必占有較重要的地位,本文設計實現(xiàn)了一種基于的智能系統(tǒng),通過智能車為平臺搭載和攝像頭,運用AprilTag 標定跟蹤與 控制[2] 實現(xiàn)機器人的移動與跟蹤抓取。最終實現(xiàn)自動導航以及智能識別并搬運物品的功能。

1 機器人工作原理

1.1 控制算法

控制是指比例、積分、微分控制。將系統(tǒng)的測量反饋經(jīng)過比例、積分、微分3 種運算后,疊加至輸入中,達到控制的目的。其原理簡單、易于實現(xiàn),被應用于多種領域。常用的PID 算法有兩種,一種是位置式PID,另一種是增量式PID,兩者應用場合不同,各有優(yōu)點。位置式PID 算法的表達式為:

1682484172369615.png

其中,Kp為比例放大系數(shù),Ti為積分時間常數(shù),Td為微分時間常數(shù)。

位置式PID 算法是根據(jù)當前實際測得的輸出與要達到的預期輸出的偏差e(k),進行 PID 運算。由于積分項會對每一次的誤差進行累加,使其運算量較大,且每次輸出均與過去的狀態(tài)相關,可能會引起大幅度超調。適用于執(zhí)行機構不帶積分部件的對象,如電液伺服閥。

增量式PID 算法的表達式為:

1682484275915238.png

增量式 PID 公式是由將位置式 PID 的輸出 u(k) ?u(k?1) = Δu(k)得到,而不是對應與實際位置的偏差,沒有誤差累積。也就是說增量式PID 中不需要累加??刂圃隽喀?em>u(k)的確定僅與最近 3 次的采樣值有關。所以增量式PID 容易通過加權處理獲得比較好的控制效果,相較于位置式PID 算法,在系統(tǒng)發(fā)生問題時,增量式PID 不會嚴重影響系統(tǒng)的工作。適用于執(zhí)行機構帶積分部件的對象,如步進電機等。

1682484331853761.png

圖1 PID控制系統(tǒng)圖

1.2 視覺定位算法

AprilTag 是一種視覺基準系統(tǒng),通過特定的標志快速檢測出相對位置,AprilTag 庫不需要依賴,可以輕松移植到嵌入式裝備中。AprilTag 視覺定位[3] 實現(xiàn)主要分為三個部分:邊緣檢測,四邊形檢測,匹配與解析,其流程如圖2所示。

1682484406168401.png

圖2 視覺定位算法流程圖

首先對圖像提取邊緣,查找邊緣中邊數(shù)大于四的凸 多邊形,在查找到的多邊形中篩選出四邊形。對四邊形中的圖像進行編碼,白色為0,黑色為1,1 個四邊形有4 個編碼,分辨是當前圖像的編碼和進行3 次90°旋轉后的編碼,計算與庫中編碼的最小海明距離。如果海明距離小于閾值,則認為其為AprilTag,可確定其ID,并通過矩陣變換得到位姿信息。

1.3 運動學

運動學[4] 研究的是通過建立機械臂運動學模型、分析機械臂各關節(jié)的位姿、速度、加速度與機械臂末端在空間中的變換規(guī)律。正運動學通過各個關節(jié)之間的關系,求出機器人末端執(zhí)行器的位姿,以關節(jié)角度作自變量,建立機械臂的正運動模型。

為方便的表達兩個相鄰關節(jié)連桿的參數(shù)關系,需要對所有關節(jié)指定一個參考系,D-H 參數(shù)法是一種常用的對機器人相鄰兩個連桿之間參數(shù)關系建模的數(shù)學方法,其中的參數(shù)有5 個:

1684401672750931.png

1682484854693796.png

各個關節(jié)坐標系之間的變換矩陣依次相乘,求出從基坐標系到機械臂末端執(zhí)行器坐標系之間的坐標變換矩陣。

1682484919131161.png

1684401843165585.png

1682485185528954.png

圖3 機械臂簡化幾何模型

1684401891839957.png

2 機器人硬件設計

2.1 硬件總體設計

本文基于 設計的智能系統(tǒng),選取性能較好的硬件配置作為系統(tǒng)運行的外部環(huán)境支撐,根據(jù)搬運機器人機械系統(tǒng)功能和技術指標,設置硬件總體結構。系統(tǒng)硬件設備包括攝像頭模塊、OLED 顯示器、轉向舵機、直流電機,系統(tǒng)硬件結構圖,如圖4 所示。

1682504424718052.png

圖4 系統(tǒng)硬件結構圖

智能系外部設備較多,各設備之間工作電壓不一致。本文采用了LM2596 和AMS1117 兩顆降壓芯片,調整系統(tǒng)運行時的電壓、攝像頭模塊和機械臂是機器人抓取目標的基礎硬件設備、直流電機和轉向舵機能控制機器人的移動和方向,OLED 顯示系統(tǒng)運行時的各種參數(shù),是調試時的重要依據(jù)。

2.2 移動與轉向設計

本文所設計的機器人移動采用兩路帶光電編碼器的直流電機,通過 輸出PWM 波,同時接收編碼器計數(shù),經(jīng)處理后達到控制調速目的。OLED 模塊顯示設定速讀和實時速度,選擇TB6612 模塊作為直流電機驅動給電機供電。所有模塊形成一個完整的速度閉環(huán)控制,能對直流電機穩(wěn)定快速準確的調速。機器人的轉向在舵機與連桿連接兩個前輪的方式下,通過STM32 輸出PWM 波控制舵機的轉動從而帶動兩個前輪同步轉動以達到轉向的目的。前輪的束腳[5] 為0° ,從而在不影響轉向效果的前提下能夠穩(wěn)定地直線行駛。

2.3 機械臂設計

本文所建立的機械臂是由6 個舵機及機械零件組成,其中5個舵機組成5個旋轉關節(jié),另外1個舵機構成末端執(zhí)行器機械爪,整體為5自由度,其D-H參數(shù)表如表1 所示。

1682504548641178.png

2.4 機器人視覺設計

本文選用 模塊承擔機器人的視覺功能。是集攝像頭、處理器和調試器于一體的智能攝像頭,內含豐富的圖像處理實用庫,在低算力要求下表現(xiàn)良好。將 鑲嵌到機械臂上即可通過機械臂控制攝像頭的視野以完成機器人的巡線移動或機械臂的抓取定位等功能。

2.5 電源及驅動設計

機器人電源結構如圖5 所示。

1682504615965640.png

圖5 電源結構圖

本文所設計的機器人在滿足安全穩(wěn)定的指標下,采用1 個總電源通過多級降壓為機器人的各個模塊進行供電??傠娫礊?2 V、6 000 mAH 鋰電池, 電源通過TB6612 穩(wěn)壓后給兩路直流電機供電,同時通過LM2596S-ADJ 芯片[6] 將12 V 降為7.5 V 給轉向舵機與機械臂的六個舵機供電。再將7.5 V 輸入至AMS1117-5.0 芯片輸出5 V 至OPENMV H7 模塊。最后將5 V 輸入至AMS1117-3.3 輸出3.3 V 給STM32F103C8T6 主控芯片供電。

3 機器人軟件設計

3.1 系統(tǒng)總體框架

系統(tǒng)運行流程如圖6 所示。機器人開機之后等待帶有二維碼的物品出現(xiàn),檢測到物品后,掃描物品上的二維碼獲取目標貨柜ID 信息,通過AprilTag 視覺定位獲取物品位置信息,以此控制機械臂進行準確的定位與跟蹤抓取并放入機器人的臨時貨柜中。之后機器人切換為移動狀態(tài),攝像頭識別地面黑線,通過PID 控制機器人轉向與移動直到到達目標位置后將臨時貨柜中的物品放入目標貨柜中。程序采用前后臺控制:基本功能和循環(huán)等待作為前臺程序,中斷函數(shù)為后臺程序。主程序中完成芯片外設的初始化、功能處理;中斷函數(shù)實現(xiàn)機械臂控制、電機控制、舵機控制、串口數(shù)據(jù)處理、狀態(tài)更新。

1682504753510280.png

圖6 軟件設計流程

3.2 視覺跟蹤

攝像頭有兩種工作模式:抓取和巡線模式。抓取模式提供物品的位置信息,巡線模式提供黑線位置信息,主控芯片管理攝像頭的模式。程序流程圖如圖7 所示。

1682504868313803.png

圖7 OpenMV程序流程圖

首先初始化攝像頭,將模式設為抓取模式,循環(huán)執(zhí)行獲得圖像、檢測AprilTag、如果存在AprilTag 則解析AprilTag位置信息、串口發(fā)送數(shù)據(jù)等操作,直到接收到模式切換命令。當收到巡線命令時,循環(huán)執(zhí)行獲得圖像、二值化、解析黑線位置和偏角信息、串口發(fā)送數(shù)據(jù)等操作。

3.3 移動與轉向控制

機器人的移動主要通過直流電機的轉動,為了能準確控制電機轉動速度,本文采用了增量式PID 算法來控制電機,其控制流程如圖8所示。

1682504950837651.png

圖8 調速流程圖

首先初始化外設,設置PWM 頻率為10 kHz,PID采樣頻率為50 Hz,即每20 ms 進行一次定時器中斷,在定時器中斷函數(shù)中對讀取到的光電編碼器計數(shù)值進行處理,STM32F103C8T6 的編碼器接口計數(shù)方向與編碼器信號的關系如表2 所示。

1682505006882281.png

當其中一路接口信號跳變時,判斷另一路的相對電平確定計數(shù)方向,在設置為4 倍頻模式下實際運行計數(shù)效果如圖9所示。

1682505040734734.png

圖9 4倍頻編碼器模式下的計數(shù)器操作實例

結合本文所用電機的物理參數(shù),減速比i ,光電編碼器線數(shù)P ,車輪半徑r ,采樣頻率f ,可得計數(shù)值Count與實際速度V 的計算公式為:

1682505128520843.png

將由公式6 得到的實際速度V 帶入增量式PID 算法公式2 中即可得到應輸出的PWM 量以修正實際測得的誤差。機器人的轉向主要通過舵機通過連桿帶動前輪實現(xiàn)轉向,在直線行駛的情況下,黑線在攝像頭中應處于圖像中間且豎直,由此確定轉向的反饋數(shù)據(jù)為黑線在圖中的偏距ρ 和偏角θ 如圖10 所示。

1682505190684954.png

圖10 攝像頭解析圖像

ρ 為黑線頂部中點與圖像寬度一半的差,θ 為黑線與圖像底部的夾角。將偏距ρ 和偏角θ 分別帶入位置式PID 算法公式,計算出的數(shù)值相加即可得到應輸出PWM 波以控制轉向舵機修正攝像頭觀測到的誤差。

3.4 機械臂控制

機械臂控制流程如圖11 所示。

1682505264385127.png

圖11 機械臂控制流程圖

在接收到目標物品的相對坐標x、y、z后,先通過正運動學由當前關節(jié)角度計算出當前末端執(zhí)行器的坐標,然后再加上物品的相對坐標,就可得到目標物品的絕對坐標X、Y、Z。通過逆運動學將目標絕對坐標位置轉換為目標關節(jié)角度,利用增量式PID 完成對機械臂的控制輸出。

4 實驗結果及分析

整合各模塊后,現(xiàn)對各模塊進行性能測試,包括電機調速性能、AprilTag 姿態(tài)獲取范圍、機械臂跟蹤能力。

4.1 機器人運動控制性能

控制系統(tǒng)性能的評價可以采用動態(tài)性能指標分析,即在典型輸入信號作用下,計算系統(tǒng)響應的上升時間tr ,峰值時間tp ,調節(jié)時間ts ,超調量σ %。以上指標可以滿足系統(tǒng)動態(tài)過程的特征體現(xiàn)。

在零初始條件下,對系統(tǒng)給定不同的階躍輸入,分別為20、40、60、80 cm/s,測試得到系統(tǒng)的響應如圖12 所示。

1684464023199067.png

通過圖 12 可知,系統(tǒng)輸出最后趨近于給定值,能夠滿足控制系統(tǒng)最基本的穩(wěn)定性要求,然后分析其動態(tài)指標如表 3。

1682934119350574.png

分析表3 動態(tài)指標可知,隨著目標速度的增大上升時間,峰值時間都略微增大,調節(jié)時間受誤差影響較大,平均調節(jié)時間為560 ms,從總體上看,系統(tǒng)響應快速,在700 ms 內穩(wěn)定至目標速度,雖然略微有部分超調,但仍在穩(wěn)定可靠范圍內,不影響整個系統(tǒng)的安全性。

4.2 AprilTag檢測范圍

實際中二維碼可能會從各個角度各種距離面向攝像頭,為保證識別準確性需要測量出二維碼的有效范圍。經(jīng)過測試后有效范圍如表4 所示。

1682934215209818.png

其中坐標軸以機械臂末端執(zhí)行器關節(jié)為原點,關節(jié)軸指向為Z 軸,X 軸與Y 軸分別為初始狀態(tài)下的水平與豎直方向。由表4 分析可知,AprilTag 能在攝像頭15.8 cm 的距離內準確識別,左右范圍19.6 cm,上下范圍12.4 cm 內能檢測到AprilTag。同時ArilTag 與攝像頭在70.8° 的夾角內能夠被識別到??傮w來講已經(jīng)能夠滿足機器人的視覺功能要求。

4.3 機械臂控制性能

機械臂為機器人物流功能的主要執(zhí)行器,由于其控制模型為多輸入多輸出,涉及坐標變換較為復雜,系統(tǒng)響應曲線不能直觀的表達系統(tǒng)的動態(tài)指標,所以本文采用末端執(zhí)行器距目標位置的距離隨時間的變化來反應機械臂的控制性能。如圖13 所示。

image.png

圖13 末端執(zhí)行器與目標距離的變化

在距離末端執(zhí)行器5 cm 時機械臂到達目標位置并開始抓取,抓取后距離不再變化。機械臂從目標物品出現(xiàn)到完成抓取用時2.5 s,一開始快速接近目標物品,靠近目標后不斷修正位置直到能抓取目標物品。靠近目標后沒有過多的振蕩滿足了快速性的同時也能保證系統(tǒng)的安全。相較于傳統(tǒng)開環(huán)控制,減少了振蕩,提高了系統(tǒng)的穩(wěn)定性與抗干擾能力,大幅提高了抓取的成功率。

5 結束語

本文設計了基于STM32 的智能物流機器人,采用了PID 算法控制機器人移動與機械臂抓取,優(yōu)化了物流機器人的控制性能,提高了系統(tǒng)的穩(wěn)定性,實現(xiàn)了精準的識別與抓取物品。但本文設計的機器人未優(yōu)化網(wǎng)絡應用層協(xié)議,沒有采用數(shù)據(jù)庫存儲數(shù)據(jù),希望在下一次研究中優(yōu)化機器人的網(wǎng)絡通訊,以滿足互聯(lián)的要求。

參考文獻:

[1] 董智.5G商業(yè)化應用背景下“互聯(lián)網(wǎng)+物流”的發(fā)展趨勢研究[J].中國商論,2019(22):12-13.

[2] 雷慧杰.基于STM32的直流電機PID調速系統(tǒng)設計[J].現(xiàn)代電子技術,2016,39(8):165-170.

[3] 徐慶坤,竇紅乾,杜志強,李凱,譚威.基于AprilTag視覺定位的移動機器人設計[J].工業(yè)控制計算機,2022,35(4):42-43.

[4] 王裕民,秦飛舟.五自由度機械臂的運動學建模和軌跡規(guī)劃研究[J].電工技術,2022(8):62-69.

[5] 彭鋒,丁良奇,劉尚鴻,潘筱.車輪外傾角和前束角匹配研究[J].北京汽車,2021(3):21-23,31.

[6] 鄭琪,劉琳,尚冬梅,CHEN M.基于LM2596的輸出無級可調直流穩(wěn)壓電源的設計與實現(xiàn)[J].電腦知識與技術,2018,14(27):258-260.

[7] 單芝慶.基于STM32的搬運機器人機械系統(tǒng)設計[J].自動化應用,2021(6):1-6.

[8] 鄔合林.PID在機械臂位置控制中的應用[J].冶金管理,2020(19):43-44.

[9] 楊曉峰,柳笑辰,王佳奇.基于OPENMV的智能送藥小車設計[J].電大理工,2022(1):1-7.

(本文來源于《電子產(chǎn)品世界》雜志2023年4月期)



評論


相關推薦

技術專區(qū)

關閉