關於halcon基於表面的3d識別定位
基於表面的3d識別定位,即在一個3d 場景下,用3d表面模型去識別零件,得到零件的pose,這個pose是基於3D場景座標系的。
模型可以用solidworks軟體畫,儲存成.stl格式,也可以是程式生成的。
讀入檔案然後生成3d表面模型:
file:='零件模型的地址及名稱'
*‘mm’也可以是'm','dm',設定成和後續3D scene的讀入一致即可
read_object_model_3d (file, 'mm', [], [], ObjectModel3DModel, Status)
create_surface_model (ObjectModel3DModel, 0.03, [], [], SFM)
讀入3d場景:
*3d場景可以是.ply等型別的點雲
Name:='3d點雲的位置和名字'
read_object_model_3d(Name, 'mm', [], [], ObjectModel3D, Status)
接下來識別:
*可以詳細設定引數
find_surface_model (SFM, ObjectModel3D, 0.02, 0.6, 0.3, 'true', [], [], Pose, Score, SurfaceMatchingResultID)
展示結果:
ObjectModel3DResult := []
for Index2 := 0 to |Score| - 1 by 1
if (Score[Index2] < 0.11)
continue
endif
CPose := Pose[Index2 * 7:Index2 * 7 + 6]
*
rigid_trans_object_model_3d (ObjectModel3DModel, CPose, ObjectModel3DRigidTrans)
ObjectModel3DResult := [ObjectModel3DResult,ObjectModel3DRigidTrans]
endfor
Message[1] := 'Found ' + |ObjectModel3DResult| + ' object(s) in ' + TimeForMatching1$'.3' + 'ms'+' without remove noise'
ScoreString := sum(Score$'.2f' + ' / ')
Message[2] := 'Score(s): ' + ScoreString{0:strlen(ScoreString) - 4}
NumResult := |ObjectModel3DResult|
tuple_gen_const (NumResult, 'green', Colors)
tuple_gen_const (NumResult, 3, Radii)
Indices := [1:NumResult]
*
dev_clear_window ()
visualize_object_model_3d (WindowHandle, [ObjectModel3D,ObjectModel3DResult1], [], [], ['color_' + [0,Indices],'point_size_0'], ['gray',Colors,1.0], Message, [], Instructions, PoseOut)
還可以提前對3d場景資料進行去噪,平滑等預處理,在生成模型和進行識別時,可以根據需要設定不同引數來提高精確度或者加速識別。
另外halcon18.05的新功能,能限定零件的位姿和對稱性來加速識別。
相關文章
- 基於halcon的目標定位與方向確定例項
- 基於OpenCV的車牌識別(Sobel、顏色定位)OpenCV
- 負責了“基於3D的實時精準定位技術、結合的3D高精度識別3D
- 基於MATLAB公式識別Matlab公式
- 基於 WebGL 的 3D Chart 圖表Web3D
- 基於OCaml的識別程式
- 關於 API介面的一些知識分享API
- Halcon顏色識別
- 關於影像識別的問題
- halcon識別二維碼
- 基於PCA和SVM的人臉識別PCA
- 基於Yolov3的口罩識別YOLO
- 基於深度神經網路的人臉識別相關問題神經網路
- 關於不完全型別的認識型別
- 基於神經網路的OCR識別神經網路
- 基於OPENCV的手勢識別技術OpenCV
- 關於mysql基礎知識的介紹MySql
- 基於Fixed定位的框選功能
- 關於3d場景重建3D
- loadrunner 關於計算及瓶頸識別(五)
- opencv python 基於KNN的手寫體識別OpenCVPythonKNN
- opencv python 基於SVM的手寫體識別OpenCVPython
- 基於Android平臺實現人臉識別Android
- 基於百度雲的OCR識別(Python)Python
- 基於 Kotlin Native 的基本文字識別程式Kotlin
- 基於matlab的車牌識別(含子程式)Matlab
- 基於three.js的3D炫酷元素週期表JS3D
- 關於抽象類和介面的初步理解抽象
- 關於模組裡面的註冊中心
- 關於刷表法
- Hbuilder打包IOS關於定位描述問題UIiOS
- 關於position定位的一些理解
- 基於似然場的全域性定位
- 基於TensorflowLite的人聲識別在端上的實現
- 基於人工智慧的微表情識別技術人工智慧
- 基於 OpenCv 和 Python 的手指識別及追蹤OpenCVPython
- Action Recognition——基於表示的動作識別綜述
- 【實戰】基於OpenCV的水錶字元識別(OCR)OpenCV字元