引言
ArUco標記是一種基于二維碼的標記,可以被用于高效的場景識別和位置跟蹤。這些標記的簡單性和高效性使其成為機器視覺領(lǐng)域的理想選擇,特別是在需要實時和高精度跟蹤的場景中。結(jié)合機器學習和先進的圖像處理技術(shù),使用ArUco標記的機械臂系統(tǒng)可以實現(xiàn)更高級的自動化功能,如精確定位、導航和復雜動作的執(zhí)行。
本案例旨在展示結(jié)合ArUco標記和機械臂運動控制技術(shù),實現(xiàn)對機械臂的高精度控制和姿態(tài)跟蹤。通過分析和解釋腳本的不同組成部分,本文將探討如何通過機器視覺識別技術(shù)和復雜的數(shù)據(jù)處理算法,來增強機械臂的操作能力。此外,還將展示機械臂在捕捉和響應環(huán)境變化方面的能力,以及如何通過編程和算法優(yōu)化來提高整體系統(tǒng)的效率和準確性。
技術(shù)概述
機械臂-myArm 300 Pi
myArm 300 Pi是大象機器人最新出的一款七自由度的機械臂,搭載樹莓派4B 4g芯片,專門為機器人定制了ubuntu mate 20.04操作系統(tǒng)。myArm提供了7自由度的靈活性,使它超越6自由度機器人,讓機器人手臂的移動可以如同人類手臂一樣靈活。
myArm內(nèi)置接口可以進行超高難度的肘關(guān)節(jié)姿態(tài)變換,在實踐教學中,可以用于機器人姿態(tài)研究、機器人運動路徑規(guī)劃學習、機器人冗余自由度的管理和利用、正逆運動學、ROS機器人開發(fā)環(huán)境、機器人應用開發(fā)、編程語言開發(fā)和底層數(shù)據(jù)處理等多種機器人相關(guān)的學科教育。開放了樹莓派4B開發(fā)板和末端Atom近乎100%的硬件接口,可以搭配用戶個人的樹莓派4B及M5Atom的周邊配件,進行個性化的場景開發(fā),以滿足不同用戶的創(chuàng)意開發(fā)。
ArUco 碼標記
ArUco 標記是一種二維條形碼系統(tǒng),它在機器視覺領(lǐng)域中被廣泛用于標記檢測和空間定位。這些標記由黑白圖案組成,通常呈正方形,中心包含一個獨特的二進制模式,使其能夠被計算機視覺系統(tǒng)快速而準確地識別。
ArUco 標記的特點:
唯一性:每個 ArUco 標記具有獨特的編碼,允許識別系統(tǒng)輕松區(qū)分不同的標記
低成本:與其他高級定位系統(tǒng)相比,ArUco 標記不需要昂貴的設(shè)備或復雜的安裝,可以直接打印ArUco標記。
定位和導航:在機器視覺系統(tǒng)中,ArUco 標記被用作參考點,幫助機械臂或移動機器人定位自身位置或?qū)Ш街撂囟ㄎ恢谩?br />
姿態(tài)估計:通過分析攝像頭捕捉到的 ArUco 標記圖像,系統(tǒng)能夠計算出標記相對于攝像頭的位置和方向(即姿態(tài))。這對于精確控制機械臂或其他自動化設(shè)備至關(guān)重要。
相關(guān)軟件和庫
操作系統(tǒng):Ubuntu mate 20.04
編程語言:Python 3.9+
主要功能包:pymycobot,OpenCV,numpy,math
pymycobot-控制機械臂運動的庫,多種控制接口
OpenCV- 提供了豐富的圖像處理和視頻分析功能,包括對象檢測,面部識別,運動跟蹤,圖形濾波等
Numpy-是一個核心科學計算哭,它提供了高性能的多維數(shù)組對象和工具,用于處理大量數(shù)據(jù)。
Math-提供了一系列基本的數(shù)學運算函數(shù)和常量,如三角函數(shù)、指數(shù)和對數(shù)函數(shù)、各種數(shù)學常數(shù)等。
系統(tǒng)設(shè)計與實現(xiàn)
物料準備
機械臂的姿態(tài)跟蹤
定義:姿態(tài)跟蹤通常指的是監(jiān)測和記錄一個物體在三維空間中的精確位置(平移)和方向(旋轉(zhuǎn)),即其“姿態(tài)”。
技術(shù)應用:在機械臂的應用中,姿態(tài)跟蹤涉及到實時監(jiān)控和控制機械臂自身的各個關(guān)節(jié)和末端執(zhí)行器的精確位置和方向。這通常需要復雜的傳感器系統(tǒng)和算法,以實現(xiàn)高精度的控制。
用途:姿態(tài)跟蹤對于執(zhí)行精密的操作任務非常關(guān)鍵,如在制造業(yè)中的裝配、焊接、在醫(yī)療領(lǐng)域中的外科手術(shù)輔助
項目組成部分
整個系統(tǒng)的架構(gòu)主要分為以下幾個部分:
1.硬件組成:機械臂,usb攝像頭以及使用到的設(shè)備。
2.軟件和控制系統(tǒng):通過OpenCV識別ArUco 標記,控制算法,機械臂運動控制的系統(tǒng)來實現(xiàn)案例。
3.數(shù)據(jù)流程:用于圖像的捕捉,圖像處理,數(shù)據(jù)分析和轉(zhuǎn)換,機械臂的執(zhí)行。
功能實現(xiàn)
圖像捕捉
使用到OpenCV捕獲圖像的方法
# 初始化攝像頭 cap = cv2.VideoCapture(0) # 0代表默認攝像頭的序號 #讀取圖像幀 ret, frame = cap.read() #顯示圖像 cv2.imshow('video", frame) def capture_video(): cap = cv2.VideoCapture(0) if not cap.isOpened(): print("Can't open camera") return try: while True: ret, frame = cap.read() if not ret: print("Can't read the pic from camera") break cv2.imshow('Video Capture', frame) # enter 'q' quit if cv2.waitKey(1) & 0xFF == ord('q'): break finally: cap.release() cv2.destroyAllWindows()
圖像處理與ArUco標記識別
對攝像頭捕獲的圖像進行處理以及對ArUco的標記碼進行識別
#檢測ArUco標記 def detect_marker_corners(self, frame: np.ndarray) -> Tuple[NDArray, NDArray, NDArray]: # 灰度化 gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) corners : Any ids : Any rejectedImgPoints : Any corners, ids, rejectedImgPoints = self.detector.detectMarkers(gray) return corners, ids, rejectedImgPoints #在圖像中標記出ArUco碼,并且在每個標志上繪制坐標軸 def draw_marker(self, frame: np.ndarray, corners, tvecs, rvecs, ids) -> None: # cv2.aruco.drawDetectedMarkers(frame, corners, None, borderColor=(0, 255, 0)) cv2.aruco.drawDetectedMarkers(frame, corners, ids, borderColor=(0, 200, 200)) for i in range(len(ids)): corner, tvec, rvec, marker_id = corners[i], tvecs[i], rvecs[i], ids[i] cv2.drawFrameAxes(frame, self.mtx, self.dist, rvec, tvec, 30, 2) while True: ret, frame = cap.read() corners, ids, rejectedImgPoints = aruco_detector.detect_marker_corners(frame) if ids is not None: detector.draw_marker(frame, corners, tvecs, rvecs, ids) ArucoDetector.draw_position_info(frame, corners, tvecs) cv2.imshow('Video Capture', frame) # enter 'q' quit if cv2.waitKey(1) & 0xFF == ord('q'): break
數(shù)據(jù)解析與處理
因為該案例要做的是姿態(tài)跟蹤,所以我們在檢測ArUco標記的時候得檢測該姿態(tài),標注每個旋轉(zhuǎn)向量(rvec)和平移向量(tvecs),這些向量描述了標記相對于攝像頭的三位位置和方向。
def estimatePoseSingleMarkers(self, corners): """ This will estimate the rvec and tvec for each of the marker corners detected by: corners, ids, rejectedImgPoints = detector.detectMarkers(image) corners - is an array of detected corners for each detected marker in the image marker_size - is the size of the detected markers mtx - is the camera matrix distortion - is the camera distortion matrix RETURN list of rvecs, tvecs, and trash (so that it corresponds to the old estimatePoseSingleMarkers()) """ marker_points = np.array([[-self.marker_size / 2, self.marker_size / 2, 0], [self.marker_size / 2, self.marker_size / 2, 0], [self.marker_size / 2, -self.marker_size / 2, 0], [-self.marker_size / 2, -self.marker_size / 2, 0]], dtype=np.float32) rvecs = [] tvecs = [] for corner in corners: corner : np.ndarray retval, rvec, tvec = cv2.solvePnP(marker_points, corner, self.mtx, self.dist, None, None, False, cv2.SOLVEPNP_IPPE_SQUARE) if retval: rvecs.append(rvec) tvecs.append(tvec) rvecs = np.array(rvecs) tvecs = np.array(tvecs) (rvecs - tvecs).any() return rvecs, tvecs
捕獲數(shù)據(jù)的時候會大量的數(shù)據(jù),為了提高檢測的準確性需要使用濾波器來進行對數(shù)據(jù)的處理。
用到了中值濾波器,平均濾波器還有二階濾波器。
中值濾波器:中值濾波器非常有效于去除所謂的“椒鹽”噪聲,同時保持信號的邊緣信息。它在圖像處理中常用于去除噪點,同時不會使圖像模糊。
平均濾波器:平均濾波器常用于去除隨機噪聲、平滑和軟化數(shù)據(jù)。在圖像處理中,它可以用于平滑圖像,但可能會導致邊緣信息丟失,可以看到圖像處理過后會模糊一些。
二階濾波器:精確控制信號頻率成分時使用,例如在信號處理和控制系統(tǒng)中,用于減少振蕩和提高穩(wěn)定性,特別是在姿態(tài)估計和精確運動控制中。
def median_filter(pos, filter, filter_len): if not np.any(filter): # 如果濾波器為空,用pos填充濾波器 filter[:] = pos # 將pos加入濾波器 filter[filter_len - 1] = pos # 移動濾波器中的元素 for i in range(filter_len - 1): filter[i] = filter[i + 1] # 計算中值并存儲到輸出數(shù)組中 output = np.median(filter) return output def Average_filter(pos, filter, filter_len): if not np.any(filter): # 如果濾波器為空,用pos填充濾波器 filter[:] = pos # 將pos加入濾波器 filter[filter_len - 1] = pos # 移動濾波器中的元素 for i in range(filter_len - 1): filter[i] = filter[i + 1] # 計算中值并存儲到輸出數(shù)組中 output = np.mean(filter) return output def twoorder_filter_single_input(input): global prev1 global prev2 global prev_out1 global prev_out2 if np.array_equal(prev1, np.zeros(3)): output, prev1, prev_out1 = input, input, input return output if np.array_equal(prev2, np.zeros(3)): prev2, prev_out2 = prev1, prev_out1 output, prev1, prev_out1 = input, input, input return output fc = 20 # Hz 截止頻率 (設(shè)計的濾波器頻率) fs = 100 # Hz 斬波頻率 (采樣頻率) Ksi = 10 # 品質(zhì)因數(shù) temp1 = (2 * 3.14159 * fc)**2 temp2 = (2 * fs)**2 temp3 = 8 * 3.14159 * fs * Ksi * fc temp4 = temp2 + temp3 + temp1 K1 = temp1 / temp4 K2 = 2 * K1 K3 = K1 K4 = 2 * (temp1 - temp2) / temp4 K5 = (temp1 + temp2 - temp3) / temp4 output = K1 * prev2 + K2 * prev1 + K3 * input - K4 * prev_out2 - K5 * prev_out1 # 更新全局變量 prev2, prev1, prev_out2, prev_out1 = prev1, input, prev_out1, output return output
從檢測到的標記(如ArUco標記)中提取機械臂或相機的姿態(tài)信息,并對提取的角度數(shù)據(jù)進行濾波處理,最終獲得目標的坐標。
機械臂控制命令生成
在機械臂運動控制的方式上,我們得設(shè)置它的運動模式
# Set end coordinate system 1-tool arm.set_end_type(1) time.sleep(0.03) # Set tool coordinate system arm.set_tool_reference([-50, 0, 20, 0, 0, 0]) time.sleep(0.03) # Set command refresh mode arm.set_fresh_mode(0) time.sleep(0.03)
在獲取到目標坐標,就得發(fā)送給機械臂去執(zhí)行命令。
from pymycobot import MyArm
arm = MyArm("COM11",debug=False)
# 發(fā)送坐標控制機械臂運動
arm.send_coords(target_coords, 10, 2)
關(guān)鍵技術(shù)點
關(guān)鍵的技術(shù)點主要在幾個方面:
ArUco 檢測:
ArUco 標記的檢測是整個系統(tǒng)運行的基礎(chǔ)。通過攝像頭識別這些標記,系統(tǒng)能夠獲取關(guān)于標記位置和方向的關(guān)鍵信息。這些信息對于機械臂的精確控制和操作至關(guān)重要,尤其是在需要精確位置調(diào)節(jié)的應用中,如在自動化、機器人編程和增強現(xiàn)實中。
使用圖像處理技術(shù),用openCV庫從攝像頭捕獲的圖像中識別標記,并且提取他們的位置和姿態(tài)信息。
濾波技術(shù):
在處理圖像數(shù)據(jù)或機械臂傳感器數(shù)據(jù)時,濾波技術(shù)是保證數(shù)據(jù)質(zhì)量和系統(tǒng)穩(wěn)定性的關(guān)鍵。它們幫助去除數(shù)據(jù)中的噪聲和誤差,從而提高系統(tǒng)的準確性和可靠性。
機械臂控制:
在開始實現(xiàn)機械臂姿態(tài)跟蹤前提,需要設(shè)置其運動模式。確保機械臂的運動與預期任務相匹配、提高操作的精度和可靠性非常關(guān)鍵。通過調(diào)整坐標系統(tǒng)、工具參考點和指令執(zhí)行方式,可以使機械臂更加適應特定的操作環(huán)境和任務需求。
https://twitter.com/i/status/1733806097050558951
總結(jié)
在該項目中,深入了解圖像處理和機器視覺的原理,特別是ArUco標記檢測和位姿最終方面??梢哉莆崭鞣N濾波技術(shù)的應用,理解它們在提高數(shù)據(jù)質(zhì)量和系統(tǒng)性能中的重要??偠灾?,該項目可以實踐應用各個方面。
審核編輯 黃宇
-
機器人
+關(guān)注
關(guān)注
211文章
28418瀏覽量
207103 -
開源
+關(guān)注
關(guān)注
3文章
3349瀏覽量
42501 -
python
+關(guān)注
關(guān)注
56文章
4797瀏覽量
84690 -
機械臂
+關(guān)注
關(guān)注
12文章
515瀏覽量
24588
發(fā)布評論請先 登錄
相關(guān)推薦
評論