在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

3D深度機器視覺和機器臂的無序抓取

大象機器人科技 ? 來源:大象機器人科技 ? 作者:大象機器人科技 ? 2023-05-04 11:25 ? 次閱讀

pYYBAGRTHZuABFRNAJCGQgMx-24402.png

今天我記錄使用myCobot320 M5跟FS820-E1深度相機進行一個無序抓取物體的分享。

為什么會選擇深度相機和機械臂做一個案例呢?

2D相機(最常見使用的相機)可以捕捉二維圖像,也就是在水平和垂直方向上的像素值。它們通常用于拍攝靜態場景或移動的物體,并且無法提供深度信息。在機器視覺應用中,2D相機可以用于圖像分類、目標檢測和識別等任務。

相比之下,深度相機可以捕捉深度信息,因此可以獲得物體的三維信息。這些相機使用各種技術來測量物體的深度,如結構光、時間飛行和立體視覺等。在機器視覺應用中,3D相機可以用于點云分割、物體識別和3D重建等任務。

2D相機捕獲到的信息已經滿足不了一些特殊的情況,所以換上深度相機獲得的更多的信息,比如說物體的長寬高。

讓我們開始今天的主題。

FS820-E1

相機的環境搭建

首先我要搭建FS820-E1的開發環境,使用的是相機提供的RVS進行開發。可以利用RVS中的視覺算子寫成節點(Node)快速搭建抓取功能。

pYYBAGRTIt6AQZncAAFNjnwVD-o667.png

RVS工作界面

實時采集數據

在左上角窗口資源中,找到TyCameraResource 算子添加到算子圖中的 ResourceGroup 中,在算子列表搜索TyCameraAccess,trigger算子分別添加到算子圖中,并根據需要調整算子參數。然后點擊運行和屬性面板Trigger->ture即可查看可視化數據。沒有報錯能正常顯示即可進行下一步。

TyCameraResource 算子

●start 以及 stop 分別用于開啟、關閉資源算子的線程。auto_start 也是用于開啟資源算子,如果勾選,則僅在打開 RVS 軟件后第一次進入運行狀態時自動開啟資源線程。

●reset:在打開資源線程后如果需要更改屬性參數,需要選中該選項進行重置。

TyCameraAccess 算子

●打開cloud、rgb、depth可視化屬性,將 cloud_color設置為-2,代表真實顏色

poYBAGRTIu2AYg0VAAEFCcv9r70402.png

myCobot 320-M5Stack

myCobot 320 是面向用戶自主編程開發的實踐型機器人,產品最大有效臂展 350mm,最大負載 1KG,重復定位精度 ±0.5mm。

pYYBAGRTIvaANaAwAAC-3LaY3P0114.png

環境搭建

需要python 編譯環境以及控制機器人的庫pymycobot

pip install pymycobot --upgrade

poYBAGRTIv2AO6LMAACs1uwyjVc298.png

ps:使用的PC的顯卡最好是1060 2G獨顯以上,因為需要鍛煉圖片識別等操作,顯卡的性能越好運行得越快

無序抓取

接下來是實現機械臂的無序抓取,無論物體處于何種姿態都能過精準的抓到。下圖是整體的算子圖,也就是unstacking.xml工程文件

poYBAGRTIwyARiOqAAOl4OfWQ6g876.png

手眼標定

用棋盤格來進行手眼標定

準備:

●準備棋盤格,算好棋盤格行列數,以及棋盤格邊長(mm)

●手眼標定分為眼在手上(eye in hand)、眼在手外(eye to hand)。根據不同情況將標定板和相機固定好。這里選擇eye to hand

pYYBAGRTIxqATaYoAALjYF002zY611.png

數據錄制

點擊左上角加載,打開unstacking_runtime/HandEyeCalibration/HandEyeCalibration.xml

poYBAGRTIyaAPrMEAAJWSvB9djA569.png

在屬性面板正確填寫標定板的行列數,和標定板格子的單位長度,和數據保存的文件路徑

poYBAGRTIy2AKX7SAACaAK2JiEU516.png

啟動相機工程和機械臂開始進行標定.

標定前確保相機能完整識別完整的棋盤格,以及標定過程中,棋盤格是固定的,不能發生移動。運行完成會得到18組數據。

pYYBAGRTIzeAF9yIAAWUbP4rBG8325.png

計算標定結果

positional error 在 0.005(5 毫米)以內,則比較理想

poYBAGRTI0uAb6mGAAK-pjOwDYw833.png

poYBAGRTI22APX6KAAB9yfYRxdY517.png

坐標系轉換

此操作旨在將點云所處的坐標系——相機 rgb 鏡頭坐標系轉換至機器人坐標系,這一轉換涉及相機外參及手眼標定結果。

步驟:

●1)在算子圖中右鍵選擇在此處導入Group XML,導入RVSCommonGroup 中的HandToEye_Depth2Robot.group.xml。需要注意的是,除了該文件之外 ,還有HandInEye_Depth2Robot.group.xml。

●2)加載手眼標定數據組的pose端口與HandToEye_Depth2Robot組的rgb2robot 端口連接。

●3)拖入 LoadCalibFile 算子,用于加載標定文件,finshed 端口連接至HandToEye_Depth2Robot組的start端口;extrinsic_pose端口與rgb2depth 端口連接;start端口與InitTrigger端口finished端口連接。具體連接如下:

poYBAGRTI36Ab1IYAAIjbafw12g514.png

點擊 Group,找到 rgb2tcp 算子,在屬性面板的 pose 屬性處,粘貼手眼標定的結果。

pYYBAGRTI4iALgB6AAJUez-6YYU585.png

●5)通過前述步驟,我們已經獲取了相機 rgb 鏡頭轉機器人坐標系的矩陣 rgb2robot 和相機深度鏡頭轉機器人坐標系的矩陣 depth2robot,此處我們將相機深度鏡頭坐標系下點云轉換至機器人坐標系下。

●6)首先拖入 Transform 算子,type 屬性選擇“PointCloud”,將 depth2robot 端口連接至該算子的pose 輸入端口,將 LoadLocalData 算子組的 pointcloud 端口連接到本算子的同名輸入端口。

poYBAGRTI-WAIQGHAAIHlY7T9JU660.png

AI訓練

采集訓練圖像

打開 unstacking_runtime/MaskRCNN/ty_ai_savedata.xml,內容基本與錄制 RGB 圖像一致,在這里我們只需要調整 EmitSring 中的 string 參數,設置為我們想要的路徑即可。點擊 Capture 錄制圖像。當然數據越多那是越好,越穩定。

pYYBAGRTI_eAJBRfAAIJ1KqPwFc614.png

標注訓練模型

目前為已錄制好的 RGB 標注,我們推薦使用 labelme 這款軟件,本文檔提供一種 labelme 的安裝方法。

●1.按照官網安裝pip

https://pip.pypa.io/en/stable/installation/

●2.安裝PyQt5

pip install PyQt5

●3.安裝labelme

pip install labelme

標注前準備

首先確定任務目標,明確在檢測過程中什么物體需要被檢測,什么物體不需要被檢測,從而有針對性的進行標注。

給定的標注條件無需過分苛刻,不要按照人的思維去考慮,而是按照自己主觀設定的標注思路是否便于落實代碼。

標注過程

●終端輸出labelme,打開軟件點擊OpenDir,選擇我們標注的路徑(在3.2.1采集訓圖像Emit算子string路徑)

●點擊Create Polygons,為木塊繪制紅色的邊框

●完成后會彈出命名框,第一次請命名 wooden block,后續同類直接選擇

●當圖像內所有箱子標注完成后,點擊 Save 進行保存,默認當前文件夾,默認名稱,隨后選擇 Next Image 切換到下一個圖像

訓練AI模型

開unstacking_runtime/MaskRCNN/ty_ai_train.xml,這里只需要調整 data_directory 和classnames _filepath 路徑。點擊 start_train按鈕即開始訓練。

最終會生成一個 train output 文件夾在這個文件夾中有命名為 model fial,pth是所需要的權重文件。

AI推理

1)拖入一個 Emit 算子,type 屬性選擇“pose”,重命名為“抓取參考Pose”,將 pose_roll 輸入入“3.141592654”。這個算子在后續的算子中使用。將該算子中 pose 端口與計算抓取點組down_pose 端口連接

2)雙擊展開計算抓取點組,需要預先使用 MaskRCNN 網絡對數據進行訓練,將其中的AIDetectGPU 算子的 type 更改為MaskRCNN 并對應修改其余配置文件參數。由于 AI 推理算子在正式運行前需要初始化運行一次,所以需要在算子前額外添加一個 Trigger(type 為 InitTrigger)。

3)AI 推理算子會獲得目標在 2D 圖像中的位置區域(即掩碼圖,對應的是 obj_list 端口),之后我們需要將這些位置區域轉換到 3D 點云中,這一環節對應的是 計算抓取點 組中的 ProjectMask 算子。對于 ProjectMask 算子,不僅需要給入 AI 推理算子獲得的 obj_list,還需要給入 2D 圖對應的點云、2D圖采圖時所用的 rgb 鏡頭坐標系同點云坐標系的轉換矩陣、相機 rgb 鏡頭的內參。這里已經將點云轉換到了機器人坐標系,所以需要輸入 rgb 鏡頭到機器人坐標系的轉換矩陣。相機的 rgb 鏡頭內參可以直接從相機參數文件中讀取。算子運行完成后,會獲得所有檢測目標的點云列表。

poYBAGRTJCWAKll-AAEwQY5UNvY471.png

機械臂定位抓取

定位識別

根據 AI 推理后的流程,已經獲得了在機器人坐標系下所有檢測目標的點云列表。接下來要獲得它的點云中心坐標。

1)雙擊展開 計算抓取點 組中 尋找目標 組。需要先篩選木塊,并按照木塊列表的 Z 軸坐標值進行篩選,篩選出最上層的木塊,并對上層木塊進行排序。因此這里使用 FilterBoxList 算子,重命名為“點云高度排序”,該算子的屬性值調整如下:

2)獲取平面,使用 FindElement,type 選擇“Plane”,獲得點云中適合抓取的平面。調整算子屬性distance_threshold 來調整所選取的平面。打開 cloud 可視化屬性來查看選取的平面。

3)獲取平面中心點,使用 MInimumBoundingBox 算子,重命名為“獲得外包框”,type 屬性選擇“ApproxMVBB”獲得一個方便機器人抓取的坐標中心點。這里需要給該算子一個 ref_pose,這里連接在3.3.4進行AI推理中提到的“TowardsDownPose”,表示繞著 X 軸旋轉 180°,使 Z 軸朝下,便于機器人抓取。打開“GetBoxCube”屬性面板 box 和 box_pose 可視化屬性即可顯示計算出的平面中心點。

4)調整木塊方向,使用AdjustBoxNode算子,該算子的作用是,選擇長度大于寬度的物體,將物體位姿進行改變,這里選擇yaw選擇90°

poYBAGRTJEyAHLyOAAKcVVNTMCM043.png

這樣就能夠獲取到坐標了

機械臂的抓取

在完成上述操作后,已經獲得了目標點坐標,需要通過機器人和RVS軟件建立連接并進行 tcp通訊。進行實際抓取。

1)編寫TCP通訊代碼(RobotControl_Elephant.py),以下部分為截取,該代碼實現RVS軟件和機械臂的TCP通訊

#CAPTURE print("***get pose***%s"%time.asctime()) capture_cmd = "GET_POSES n" capture_bytes=bytes(capture_cmd,encoding="utf-8") sock_rvs.send(capture_bytes) #recv CAPTURE data = sock_rvs.recv(socket_buf_len) print("---------------------------接收的數據----------------------------") print(data) print("***data end***%s"%data[-1:]) print("***capture_receive***%s"%time.asctime()) if int(data[-1:]) == 1: print("***received CAPTURE result***n") if int(data[-1:]) == 2: print("***All finished!***" #P_FLAG = bool(1-P_FLAG) #print("切換拍照位") continue #break

2)將目標點進行調整坐標?例,將 ScalePose 算?的 type 設置為 Normal ,分別調整 pose 的( X 、Y 、Z )和( Roll 、Pitch 、Yaw)?例。scale_rpy:修改 pose 中 r p y 的單位。設:57.2957795 。即從將弧度切換為?度。

3)最后,將ScalePose的 finished 和pose_list端口連接到最外層算子組的 MirrorOutput 端口, 并連接回 HandEyeTCPServer算子。至此,項目文件的編輯已經完成。

poYBAGRTJKGAeIEhAAPrpAfKfYc391.png

效果展示

完成以上步驟,在unstacking.xml工程下,點擊運行,同時運行RobotControl_Elephant.py文件,識別到多個木塊選取其中一個木塊位姿就會發送給機械臂進行夾取。

poYBAGRTJLSAUSlcAID0gkdKWNA057.png

總結

總的來說這只是深度相機的一小點功能,后續甚至考慮將這幾個物體疊在一起又或者其他的不規則形狀來體現出它性能的強大。提前訓練好模型,就能實現想要的效果。你期待我用它來做些什么呢?歡迎在地下留言,你們的點贊和關注將是我更新的動力!

審核編輯黃宇

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

    關注

    9

    文章

    2947

    瀏覽量

    109383
  • 機器視覺
    +關注

    關注

    163

    文章

    4503

    瀏覽量

    122117
  • 機械臂
    +關注

    關注

    13

    文章

    542

    瀏覽量

    25202
  • 大象機器人
    +關注

    關注

    0

    文章

    85

    瀏覽量

    57
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    人形機器3D 視覺路線之爭:激光雷達、雙目和 3D - ToF 誰更勝一籌?

    電子發燒友網報道(文 / 吳子鵬)在人形機器人的設計方案中,3D 視覺技術是實現環境感知與智能化決策的核心支撐之一。它能夠助力人形機器人完成環境感知與建模、動態目標檢測與跟蹤、物體操作
    的頭像 發表于 04-15 00:14 ?2308次閱讀

    大象機器人攜手進迭時空推出 RISC-V 全棧開源六軸機械產品

    拖拽式編程(myBlockly)與Python雙開發模式,支持ROS2 RVIZ/MoveIt仿真,實現產線級數字孿生調試;預裝OpenCV、PyMyCobot等庫,10分鐘即可完成機械抓取+AI視覺
    發表于 04-25 17:59

    復合機器抓取精度的影響因素及提升策略

    復合機器人結合了移動機器人(如AGV)和機械的功能,廣泛應用于物流、制造等領域。抓取精度是其核心性能指標之一,直接影響作業效率和產品質量。本文將探討復合
    的頭像 發表于 04-12 11:15 ?203次閱讀

    昨日,杭州3D視覺傳感器公司獲數億元融資!

    2025年4月7日,杭州藍芯科技有限公司(以下簡稱“藍芯科技”)正式宣布完成由鯤鵬基金領投的C+輪融資,融資金額數億元。 目前藍芯科技產品涵蓋3D視覺傳感器、移動機器人、人形機器人、移
    的頭像 發表于 04-08 18:13 ?594次閱讀
    昨日,杭州<b class='flag-5'>3D</b><b class='flag-5'>視覺</b>傳感器公司獲數億元融資!

    3D到AI,機器視覺全面賦能工業自動化

    的統計數據,2023 年全球機器視覺市場規模約為 925.21 億元,同比增長約 5.80%,預計 2025 年將超過 1100 億元。 ? 當前,機器視覺技術發展呈現出兩大顯著趨勢
    的頭像 發表于 04-08 01:03 ?1724次閱讀

    DLP160CP DMD是否可以應用于機器視覺應用?

    關于DLP160CPDMD芯片有一個疑問, 請問該芯片是否可以應用在機器3D視覺(結構光)場景應用呢?我在TI TLP機器視覺,“
    發表于 02-20 07:39

    機器3D視覺傳感器需求爆發!英特爾、奧比中光領跑,百億市場爭奪戰開啟

    電子發燒友網報道(文/莫婷婷)隨著機器人應用場景的多樣化和智能化需求的提升,3D視覺傳感器因其能夠提供高精度的環境感知和物體識別能力,成為機器人實現自主操作、導航和交互的關鍵技術。目前
    的頭像 發表于 02-12 00:12 ?2009次閱讀

    解決方案 3D 視覺機器人賦能汽車制造新征程

    隨著智能化技術的不斷發展,汽車制造企業正積極尋求提升智能化水平的途徑。富唯智能的3D視覺引導機器抓取技術為汽車制造企業提供了一種高效、智能的自動化解決方案。
    的頭像 發表于 12-25 15:00 ?394次閱讀
    解決方案 <b class='flag-5'>3D</b> <b class='flag-5'>視覺</b><b class='flag-5'>機器</b>人賦能汽車制造新征程

    探索3D視覺技術在活塞桿自動化抓取中的應用

    隨著工業4.0時代的到來,智能制造成為工業發展的重要趨勢。作為智能制造的關鍵技術之一,3D視覺技術在活塞桿抓取領域的應用前景十分廣闊。
    的頭像 發表于 09-07 15:38 ?420次閱讀

    智能移動機器

    富唯智能移動機器人分為復合機器人和轉運機器人,搭載ICD核心控制器,實現一體化控制,最快可實現15分鐘現場機器人的快速部署,無縫對接產線,配合自研2
    的頭像 發表于 08-27 17:22 ?588次閱讀
    智能移動<b class='flag-5'>機器</b>人

    適用于3D機器視覺的高度可擴展的TI DLP技術

    電子發燒友網站提供《適用于3D機器視覺的高度可擴展的TI DLP技術.pdf》資料免費下載
    發表于 08-23 09:57 ?0次下載
    適用于<b class='flag-5'>3D</b><b class='flag-5'>機器</b><b class='flag-5'>視覺</b>的高度可擴展的TI DLP技術

    微視傳感高性能3D視覺產品亮相2024上海機器視覺

    近日,2024上海機器視覺展在上海新國際博覽中心隆重舉行,微視傳感攜最新的高性能3D視覺產品亮相E2館2121展位,得到廣泛關注,這次展會不僅是微視傳感展示創新技術的舞臺,更是與行業同
    的頭像 發表于 08-06 15:15 ?883次閱讀
    微視傳感高性能<b class='flag-5'>3D</b><b class='flag-5'>視覺</b>產品亮相2024上海<b class='flag-5'>機器</b><b class='flag-5'>視覺</b>展

    3D視覺技術廣闊的應用前景

    隨著工業自動化領域的迅猛進步,對制造過程中抓取作業的精度與效率提出了更為嚴苛的要求。作為機械構造中的核心組件,活塞桿的精準抓取成為了保障產品質量、提升生產效率的關鍵環節。在此背景下,3D視覺
    的頭像 發表于 07-29 15:56 ?589次閱讀
    <b class='flag-5'>3D</b><b class='flag-5'>視覺</b>技術廣闊的應用前景

    紙箱的拆碼垛,3D視覺引導機器無序抓取

    在繁忙的物流倉庫中,紙箱的拆碼垛工作常常讓人頭疼不已。但是,現在有了富唯智能的3D視覺引導紙箱拆碼垛解決方案,這一切都變得輕松簡單!
    的頭像 發表于 06-17 16:59 ?510次閱讀
    紙箱的拆碼垛,<b class='flag-5'>3D</b><b class='flag-5'>視覺</b>引導<b class='flag-5'>機器</b>人<b class='flag-5'>無序</b><b class='flag-5'>抓取</b>
    主站蜘蛛池模板: 免费国产在线视频 | 久久中文字幕综合婷婷 | 婷婷激情五月 | 可以在线看黄的网站 | 影视精品网站入口 | 国产91丝袜在线播放九色 | 色老头一区二区三区在线观看 | 国产三级香港三级人妇 | 欧美一级黄视频 | 日本特黄视频 | 夜夜夜网| 一区二区三区高清 | 亚洲国产综合人成综合网站00 | 国产图片综合 | 亚洲乱码尤物193yw在线播放 | 看黄网站在线看 | 色综合久久久久久久久久久 | 蜜月mv国产精品 | 亚洲成人综合在线 | 婷婷在线观看香蕉五月天 | 一色屋成人免费精品网站 | www.五月激情 | 国产午夜在线观看视频播放 | 亚洲一本之道在线观看不卡 | 日本69sex护士hd | 美女久久久 | 一级片在线免费播放 | 天天躁夜夜躁狠狠躁躁 | xxx亚洲日本 | 91无毒不卡 | 欧美.成人.综合在线 | 久久久综合色 | 日本全黄视频 | 国产又大又黄又粗又爽 | 国产亚洲自在精品久久 | 色综合天天综久久久噜噜噜久久〔 | 丁香月婷婷| 亚洲伊人天堂 | 三级亚洲 | 2019天天射干| 色狠狠一区二区 |