关于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基于表面的3d识别定位相关推荐
- C#基于Emgucv的圆形识别定位方法
C#基于Emgucv的圆形识别定位方法 在非标自动化行业工作好多年,在高精度运动控制中,机器视觉应用非常广泛.因此在本文章简单分享一种基于Emgucv开发的图像识别定位方法.第一次写博客,不太习惯这个 ...
- Halcon Solution Guide 3-C 3D Vision 学习总结(1)
1.运用3D视觉需要哪些基础知识 首先,相机标定是最基本的,不复杂,几行代码搞定.你可以利用相机标定,将图像处理的结果转换成三维信息.第三章将展示如何用单个相机在特定平面上完成一个普通的3D视觉任务. ...
- Halcon基于形状的几何定位函数说明
Halcon基于形状的几何定位函数说明 1. create_shape_model(Template: : //reduce_domain后的模板图像 NumLevels,//金字塔的层数,可设为&q ...
- python人脸识别opencv_基于python+OpenCV模块的人脸识别定位技术
什么是OpenCV模块 OpenCV是一款跨平台的视觉库,可以支持的操作系统有Linux.Windows和Mac OS操作系统,并且还提供了多种语言的接口,比如Python,java,MATLAB等常 ...
- 【原】基于matlab的蓝色车牌定位与识别---绪论
本着对车牌比较感兴趣,自己在课余时间摸索关于车牌的定位与识别,现将自己所做的一些内容整理下,也方便和大家交流. 考虑到车牌的定位涉及到许多外界的因素,因此有必要对车牌照的获取条件进行一些限定: 一.大 ...
- 【MATLAB图像处理实用案例详解(3)】—— 基于阈值分割的车牌定位识别
目录 一.背景意义 二.理论基础 2.1 车牌区域分割: 2.2 车牌定位及裁剪 三.算法流程 3.1 车牌图像处理 3.1.1 图像灰度化 3.1.2 图像二值化 3.1.3 图像边缘检测 3.1. ...
- 基于ROS机器人的3D物体识别与三维重建(三)基于ROS的3D物体识别
Kinect2相机标定与点云数据获取 1.介绍 2 基于Gazebo搭建物体识别仿真环境 2.1 Gazebo简介 2.2 创建仿真环境 3 三维物体识别 3.1 基于模板匹配的物体识别流程 3.2 ...
- 【自动驾驶-3D目标检测】3DSSD:基于点的3D单级目标检测器
3DSSD:基于点的3D单级目标检测器2020^{2020}2020 摘要 目前,基于体素的3D单级检测器已经有很多种,而基于点的单级方法仍处于探索阶段.在本文中,我们首先提出了一种轻量级且有效的基于 ...
- CaDDN:基于单目的3D目标检测新方法(CVPR2021)
点击上方"3D视觉工坊",选择"星标" 干货第一时间送达 作者丨元气满满的打工人 来源丨CV研习社 文章导读 导读:在自动驾驶的技术中,3D目标检测能够提更加丰 ...
最新文章
- a标签跳页传参,以及截取URL参数
- 配置Java网络应用程序的开发框架
- RunTime运行时在iOS中的应用之UITextField占位符placeholder
- 一句SQL随机查询ACCESS中的几条记录
- opensll、libcurl库安装的使用,树莓派CSI摄像头的配置,树莓派调用智能API平台实现人脸识别、树莓派配置中文环境
- 怎么用ai做出适量插画_怎么用最简单的方法,做出最炫酷的数据可视化图表?...
- MSDN上的异步socket 服务端例子
- git 停止维护了,官网无法下载
- 浅谈JavaScript函数重载
- python yield理解_python教程:迭代器,生成器与for循环机制
- 汇编语言--x86汇编指令集大全
- js代码混淆 webpack-obfuscator
- python答辩毕设ppt_如何制作优秀的毕业论文答辩 PPT?
- 第三方易支付系统源码
- 跨时区存储跨时区展示时间 | js 获取当前UTC时间
- 信息传输速率与传信率_数据、信号、码元传输速率和信息传输速率等概念
- 为什么在Google上搜不到我的网页
- 中继协作传输的SWIPT——知识扫盲
- 高晓松的《晓说》很棒,这脑袋怎么长得?
- typescript完成日期转换