halcon算法——筛选体积最大/点云数量最大的点云

18 篇文章 189 订阅 ¥19.90 ¥99.00
12 篇文章 6 订阅

在halcon里面发现点云是不能通过一个算子来实现体积最大/点云数量最大进行筛选,大多数的做法是写成一个固定的筛选范围值,进行筛选。

那么我偏要动态筛选不固定的扫描,找到多个点云里面的最大的点云怎么办呢?

方法为:

1、对点云按体积/点云数量进行排序

2、选择最大的点云的序数,存入数组

3、将筛选出来的点云保存

在没写排序算法之前,我进行了下面的尝试,下面的尝试存在弊端,你有更好的想法或者建议欢迎留言

//特别说明,下面的尝试失败了,此代码不是最终代码,欢迎指正
*计算所有点云的体积,获得点云的数据后,根据得到的最大值,获得minnvolume的值
volume_object_model_3d_relative_to_plane (Object_slected1, [0,0,0,0,0,0,0], 'signed', 'true', Volume1)
*拿到最大的体积值
tuple_max (Volume1, Max)

*筛选最大的体积值(多个的时候用这个可以筛出来)
select_object_model_3d (Object_slected1, 'volume', 'and', Max,'max' , ObjectModel3DSelected)
上面的,在只有一个点云的时候筛选不到最大的点云
将其改为下面的可以筛出来
select_object_model_3d (Object_slected1, 'volume', 'or', 0 , 'max',ObjectModel3DSelected)
问题是,上面两种情况不能同时满足


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Hi~ 可私信我了解后再进行下载~ 本资源上传时,遗漏了两个文件,分别是:data_filter_keep_order_output_index.hdvp 以及 IntensityImageToPiontsCloudImage.hdvp,购买了该资源的同学,给我留言,我会私信发给你们。 1.基于halcon算法平台; 2.提供深度图源文件以及解压密码; 3.代码预览: */****************************** * @文档名称: 基于点云的平面度测量。 * @作者: hugo * @版本: 1.1 * @日期: 2021-6-20 * @描述: 该方法支持点云的平面的平面度测量。 ********************************/ dev_update_window ('on') dev_get_window (WindowHandle) read_image (imageReal, './replay_38893_2021-6-7.tif') xResolution:=0.06 yResolution:=0.06 zResolution:=0.001 ScaleFactor:=[xResolution,yResolution,zResolution] *采样区域1 create_drawing_object_rectangle2 (300, 120, rad(90), 30, 20, DrawID) set_drawing_object_params (DrawID, 'color', 'forest green') set_drawing_object_params (DrawID, 'line_width', 1) attach_drawing_object_to_window (WindowHandle, DrawID) .......... *平面度 height:=theta/zScale*0.001 *可视化高度差效果 visParamName := ['lut','alpha_0','intensity','color_1'] visParamValue := ['hsi',0.7,'coord_z','yellow'] Labels := ['','平面度:'+height+'mm',''] objs:=[ObjectModel3Ds[2],final_ObjectModel3Ds] visualize_object_model_3d (WindowHandle, objs, [], [], visParamName, visParamValue, 'Edited by AmazingRobot+', [Labels], '', PoseOut) *stop () clear_object_model_3d (plane_balls) for Index := 0 to |final_ObjectModel3Ds|-1 by 1 clear_object_model_3d (final_ObjectModel3Ds[Index]) endfor return () 谢谢您的信任~

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大胡子大叔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值