Halcon 3D平面度

news/2024/11/19 11:27:21/

平面度是对表面形状的一种度量,用于指示该表面上的所有点是否都在同一个平面上。平面度在几何尺寸和公差(GD&T)中用平行四边形表示,当两个表面必须装配在一起形成紧密密封时,平面度就特别有用。

使用平面度公差是为了确保某个即定表面位于两个假想的、完美的、平行的平面内。换句话说,公差范围位于被测表面上最高和最低可接受点之间。

测量平面度包括分析一个表面,找出它不完全平坦的程度。为此,首先要在表面上获取一些点,以便找到包括所有这些点的两个平行平面的包络。下一步是找到尽可能小的平面夹层,而不考虑方向(因为这些平面可以在空间自由移动)。最远的两个点之间的距离就是平面度。因此,这两个平面之间的空间越窄,这个平面就越平坦。

read_image (Image, 'E:/项目/蓝膜/3d平面度检测/深度/_2022_08_27_09_33_01.tiff')
dev_close_window ()
get_image_pointer1 (Image, Pointer, Type, Width, Height)
dev_open_window (0, 0, Width/8, Height/8, 'black', WindowHandle1)
dev_display (Image)
X_power:=0.18
Y_power:=0.18
Z_power:=	0.0037
Percentage1:=40
Percentage2:=60
Percentage11:=15
Percentage12:=85
dev_get_window (WindowHandle)
dev_set_draw ('margin')
gen_empty_obj (EmptyObject)
for Index1 := 0 to 17 by 1gen_rectangle2 (Rectangle1, 2290+228*Index1, 719, 0, 300, 60)concat_obj (EmptyObject, Rectangle1, EmptyObject)
endfor
for Index1 := 0 to 17 by 1gen_rectangle2 (Rectangle1, 2290+228*Index1, 1757, 0, 300, 60)concat_obj (EmptyObject, Rectangle1, EmptyObject)
endfor
stop ()
union1 (EmptyObject, RegionUnion)median_image (Image, ImageMedian, 'square', 17, 'cyclic')
Flatness_ALL (Image, RegionUnion, X_power, Y_power, Z_power, Percentage1, Percentage2, Percentage11, Percentage12, ObjectModel3D, flatness, result)
dev_display (Image)
dev_display (EmptyObject) 

tryget_image_size (Image, Width, Height)gen_image_surface_first_order (ImageX, 'real', X_power, 0, 0, 0, 0, Width, Height)gen_image_surface_first_order (ImageY, 'real', 0, Y_power, 0, 0, 0, Width, Height)convert_image_type (Image, ImageConverted, 'real')scale_image (ImageConverted, ImageZ, Z_power, 0)reduce_domain (ImageX, ROI_Base, ROI_BaseX)reduce_domain (ImageY, ROI_Base, ROI_BaseY)reduce_domain (ImageZ, ROI_Base, ROI_BaseZ)xyz_to_object_model_3d (ROI_BaseX ,ROI_BaseY,ROI_BaseZ, ObjectModel3D1)**********************去掉最大最小**************connection (ROI_Base, ConnectedRegions)count_obj (ConnectedRegions, Number)tuple_gen_const (0, 0, Point_X)tuple_gen_const (0, 0, Point_Y)tuple_gen_const (0, 0, Point_Z)****************每个矩形区域滤掉一部分*********************for Index := 0 to Number-1 by 1select_obj (ConnectedRegions, ObjectSelected,Index+1)dev_display (ObjectSelected)reduce_domain (ImageX, ObjectSelected, ROI_BaseX1)reduce_domain (ImageY, ObjectSelected, ROI_BaseY1)reduce_domain (ImageZ, ObjectSelected, ROI_BaseZ1)xyz_to_object_model_3d (ROI_BaseX1 ,ROI_BaseY1,ROI_BaseZ1, ObjectModel3D1s)get_object_model_3d_params (ObjectModel3D1s, 'num_points', NumPoints)get_object_model_3d_params (ObjectModel3D1s, 'point_coord_z' , DistanceDistribution)tuple_sort (DistanceDistribution, Sorted)Indexs1:=int(Percentage1*0.01*NumPoints)Indexs2:=int(Percentage2*0.01*NumPoints)select_points_object_model_3d (ObjectModel3D1s, 'point_coord_z', Sorted[Indexs1],  Sorted[Indexs2], ObjectModel3DThresholded)get_object_model_3d_params (ObjectModel3DThresholded, 'point_coord_x', BaseX)get_object_model_3d_params (ObjectModel3DThresholded, 'point_coord_y', BaseY)get_object_model_3d_params (ObjectModel3DThresholded, 'point_coord_z', BaseZ)if(Index == 0)Point_X:=BaseXPoint_Y:=BaseYPoint_Z:=BaseZelsePoint_X:=[Point_X,BaseX]Point_Y:=[Point_Y,BaseY]Point_Z:=[Point_Z,BaseZ]endifendforgen_object_model_3d_from_points (Point_X, Point_Y, Point_Z, ObjectModel3Ds)dev_get_window (WindowHandle)visualize_object_model_3d (WindowHandle, ObjectModel3Ds, [], [], ['lut', 'color_attrib'], ['color1', 'coord_z'], [], [], [], PoseOut)fit_primitives_object_model_3d (ObjectModel3Ds, ['primitive_type','fitting_algorithm'], ['plane','least_squares'], ObjectModel3DOut)visualize_object_model_3d (WindowHandle, [ObjectModel3Ds,ObjectModel3DOut], [], [], ['lut', 'color_attrib'], ['color1', 'coord_z'], [], [], [], PoseOut)get_object_model_3d_params (ObjectModel3DOut, 'primitive_type', GenParamValue)get_object_model_3d_params (ObjectModel3DOut, 'primitive_parameter', PlaneValue)get_object_model_3d_params (ObjectModel3DOut, 'point_coord_x', BaseX)get_object_model_3d_params (ObjectModel3DOut, 'point_coord_y', BaseY)get_object_model_3d_params (ObjectModel3DOut, 'point_coord_z', BaseZ)***************************************获取检测点数tuple_gen_const (0, 0, Points_X)tuple_gen_const (0, 0, Points_Y)tuple_gen_const (0, 0, Points_Z)****************每个矩形区域滤掉一部分*********************for Index := 0 to Number-1 by 1select_obj (ConnectedRegions, ObjectSelected,Index+1)dev_display (ObjectSelected)reduce_domain (ImageX, ObjectSelected, ROI_BaseX1)reduce_domain (ImageY, ObjectSelected, ROI_BaseY1)reduce_domain (ImageZ, ObjectSelected, ROI_BaseZ1)xyz_to_object_model_3d (ROI_BaseX1 ,ROI_BaseY1,ROI_BaseZ1, ObjectModel3D1s)get_object_model_3d_params (ObjectModel3D1s, 'num_points', NumPoints)get_object_model_3d_params (ObjectModel3D1s, 'point_coord_z' , DistanceDistribution)tuple_sort (DistanceDistribution, Sorted)Indexs1:=int(Percentage1*0.01*NumPoints)Indexs2:=int(Percentage2*0.01*NumPoints)select_points_object_model_3d (ObjectModel3D1s, 'point_coord_z', Sorted[Indexs1],  Sorted[Indexs2], ObjectModel3DThresholded)get_object_model_3d_params (ObjectModel3DThresholded, 'point_coord_z', BaseZ)tuple_median (BaseZ, TupleZ)area_center (ObjectSelected, Area, TupleX, TupleY)if(Index == 0)Points_X:=TupleXPoints_Y:=TupleYPoints_Z:=TupleZelsePoints_X:=[Points_X,TupleX]Points_Y:=[Points_Y,TupleY]Points_Z:=[Points_Z,TupleZ]endifendforfit_3d_plane_xyz (Points_X, Points_Y, Points_Z, Ox, Oy, Oz, Nx, Ny, Nz, MeanResidual)*平面度 *点到面的距离 计算base面的平面度d1:=(Nx*Points_X+Ny*Points_Y+Nz*Points_Z-PlaneValue[3])tuple_sort (d1, Sorted1)flatness:=max(d1)-min(d1)result:=1
catch (Exception)result:=-1
endtry
return ()


http://www.ppmy.cn/news/1548218.html

相关文章

DOM NodeList 对象简介

DOM NodeList 对象简介 1. 概述 DOM(文档对象模型)是 HTML 和 XML 文档的编程接口。它提供了对文档的结构化表示,并定义了一种方式来访问和操作文档的各个部分。在 DOM 中,NodeList 是一个重要的接口,它表示节点的集…

Hadoop高可用集群工作原理

Hadoop HA集群工作原理详解 Hadoop HA集群工作原理详解概述各组件的作用1. NameNode2. ResourceManager3. JournalNode4. NodeManager5. DataNode6. ZooKeeper 配合工作方式NameNode HA工作流程ResourceManager HA工作流程JournalNode工作流程NodeManager工作流程DataNode工作流…

PyTorch和TensorFlow和Keras

PyTorch和TensorFlow PyTorch 和 TensorFlow 是当前最流行的两个深度学习框架,它们在深度学习社区中各有千秋,并且各自有不同的特点、优劣势。下面是这两者的详细比较,帮助你了解它们的异同。 1. PyTorch 简介 PyTorch 是由 Facebook&…

023、ELK 从入门到实践

ELK 从入门到实践 第一章:ELK基础概念 1.1 为什么需要ELK? 传统日志处理的痛点 日志分散 应用部署在不同服务器需要逐个登录查看无法统一管理 查询困难 只能用grep等命令无法复杂检索分析效率低 展示受限 纯文本格式无法可视化难以直观展示 ELK的解决方案 集…

Spark读MySQL数据rdd分区数受什么影响,读parquet、hdfs、hive、Doris、Kafka呢?

在Spark中,RDD(弹性分布式数据集)的分区数影响了数据的并行处理能力,不同的数据源由于数据存储方式和访问模式的不同,RDD的分区数会有所不同。以下是不同数据源(如 MySQL、Parquet、HDFS、Hive、Doris、Kaf…

Mybatis框架之单例模式 (Singleton Pattern)

MyBatis 框架中也使用到了单例模式 (Singleton Pattern),主要体现在 SqlSessionFactory 的创建和管理上。通过单例模式,MyBatis 可以确保整个应用程序中只创建一个 SqlSessionFactory 实例,从而有效地管理数据库连接资源并提高性能。下面将详…

关于Qt C++中connect的几种写法

目录 1. 传统的槽函数写法 2. 使用函数指针的connect写法(5.0) 3. Lambda表达式作为槽函数(C11) 4.使用QOverload选择重载信号的写法 这connect函数就像是编程世界里的“茴”字,千变万化,各有千秋。咱们…

自动化运维-检测Linux服务器CPU、内存、负载、IO读写、机房带宽和服务器类型等信息脚本

前言:以上脚本为今年8月1号发布的,当时是没有任何问题,但现在脚本里网络速度测试py文件获取不了了,测速这块功能目前无法实现,后面我会抽时间来研究,大家如果有建议也可以分享下。 脚本内容: #…