基于表面的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识别定位相关推荐

  1. C#基于Emgucv的圆形识别定位方法

    C#基于Emgucv的圆形识别定位方法 在非标自动化行业工作好多年,在高精度运动控制中,机器视觉应用非常广泛.因此在本文章简单分享一种基于Emgucv开发的图像识别定位方法.第一次写博客,不太习惯这个 ...

  2. Halcon Solution Guide 3-C 3D Vision 学习总结(1)

    1.运用3D视觉需要哪些基础知识 首先,相机标定是最基本的,不复杂,几行代码搞定.你可以利用相机标定,将图像处理的结果转换成三维信息.第三章将展示如何用单个相机在特定平面上完成一个普通的3D视觉任务. ...

  3. Halcon基于形状的几何定位函数说明

    Halcon基于形状的几何定位函数说明 1. create_shape_model(Template: : //reduce_domain后的模板图像 NumLevels,//金字塔的层数,可设为&q ...

  4. python人脸识别opencv_基于python+OpenCV模块的人脸识别定位技术

    什么是OpenCV模块 OpenCV是一款跨平台的视觉库,可以支持的操作系统有Linux.Windows和Mac OS操作系统,并且还提供了多种语言的接口,比如Python,java,MATLAB等常 ...

  5. 【原】基于matlab的蓝色车牌定位与识别---绪论

    本着对车牌比较感兴趣,自己在课余时间摸索关于车牌的定位与识别,现将自己所做的一些内容整理下,也方便和大家交流. 考虑到车牌的定位涉及到许多外界的因素,因此有必要对车牌照的获取条件进行一些限定: 一.大 ...

  6. 【MATLAB图像处理实用案例详解(3)】—— 基于阈值分割的车牌定位识别

    目录 一.背景意义 二.理论基础 2.1 车牌区域分割: 2.2 车牌定位及裁剪 三.算法流程 3.1 车牌图像处理 3.1.1 图像灰度化 3.1.2 图像二值化 3.1.3 图像边缘检测 3.1. ...

  7. 基于ROS机器人的3D物体识别与三维重建(三)基于ROS的3D物体识别

    Kinect2相机标定与点云数据获取 1.介绍 2 基于Gazebo搭建物体识别仿真环境 2.1 Gazebo简介 2.2 创建仿真环境 3 三维物体识别 3.1 基于模板匹配的物体识别流程 3.2 ...

  8. 【自动驾驶-3D目标检测】3DSSD:基于点的3D单级目标检测器

    3DSSD:基于点的3D单级目标检测器2020^{2020}2020 摘要 目前,基于体素的3D单级检测器已经有很多种,而基于点的单级方法仍处于探索阶段.在本文中,我们首先提出了一种轻量级且有效的基于 ...

  9. CaDDN:基于单目的3D目标检测新方法(CVPR2021)

    点击上方"3D视觉工坊",选择"星标" 干货第一时间送达 作者丨元气满满的打工人 来源丨CV研习社 文章导读 导读:在自动驾驶的技术中,3D目标检测能够提更加丰 ...

最新文章

  1. a标签跳页传参,以及截取URL参数
  2. 配置Java网络应用程序的开发框架
  3. RunTime运行时在iOS中的应用之UITextField占位符placeholder
  4. 一句SQL随机查询ACCESS中的几条记录
  5. opensll、libcurl库安装的使用,树莓派CSI摄像头的配置,树莓派调用智能API平台实现人脸识别、树莓派配置中文环境
  6. 怎么用ai做出适量插画_怎么用最简单的方法,做出最炫酷的数据可视化图表?...
  7. MSDN上的异步socket 服务端例子
  8. git 停止维护了,官网无法下载
  9. 浅谈JavaScript函数重载
  10. python yield理解_python教程:迭代器,生成器与for循环机制
  11. 汇编语言--x86汇编指令集大全
  12. js代码混淆 webpack-obfuscator
  13. python答辩毕设ppt_如何制作优秀的毕业论文答辩 PPT?
  14. 第三方易支付系统源码
  15. 跨时区存储跨时区展示时间 | js 获取当前UTC时间
  16. 信息传输速率与传信率_数据、信号、码元传输速率和信息传输速率等概念
  17. 为什么在Google上搜不到我的网页
  18. 中继协作传输的SWIPT——知识扫盲
  19. 高晓松的《晓说》很棒,这脑袋怎么长得?
  20. typescript完成日期转换

热门文章

  1. 茶楼365元会员卡锁客模式
  2. 项目管理软件dhtmlxGantt配置教程(一):指定列设置
  3. amd服务器如何修改睿频,amd自动睿频怎么开_amd开启睿频教程
  4. 考研复试个人陈述范文(共9篇)
  5. IE 兼容性问题记录
  6. [附源码]SSM计算机毕业设计高铁售票管理系统JAVA
  7. vue模板字符串中点击事件传递参数
  8. js 跨域访问问题解决方法
  9. python基础项目实战--图片转字符
  10. 暗黑2 服务器 linux,暗黑2私服多国度共享存档服务器架设指南