Halcon 3D平面度

平面度是对表面形状的一种度量,用于指示该表面上的所有点是否都在同一个平面上。平面度在几何尺寸和公差(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 1
    gen_rectangle2 (Rectangle1, 2290+228*Index1, 719, 0, 300, 60)
    concat_obj (EmptyObject, Rectangle1, EmptyObject)
endfor
for Index1 := 0 to 17 by 1
    gen_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) 

try
    
    
    get_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 1
        select_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:=BaseX
            Point_Y:=BaseY
            Point_Z:=BaseZ
        else
            Point_X:=[Point_X,BaseX]
            Point_Y:=[Point_Y,BaseY]
            Point_Z:=[Point_Z,BaseZ]
        endif
        
    endfor
    gen_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 1
        select_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:=TupleX
            Points_Y:=TupleY
            Points_Z:=TupleZ
        else
            Points_X:=[Points_X,TupleX]
            Points_Y:=[Points_Y,TupleY]
            Points_Z:=[Points_Z,TupleZ]
        endif
        
    endfor
    
    fit_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 ()
相关推荐
南宫生17 分钟前
力扣-Hot100-二叉树其二【算法学习day.33】
java·数据结构·学习·算法·leetcode·动态规划
trueEve41 分钟前
SQL,力扣题目1126,查询活跃业务
算法·leetcode·职场和发展
别开生面的阿杰1 小时前
蓝桥杯-洛谷刷题-day3(C++)
c++·算法·蓝桥杯
Mr.W.T1 小时前
JVM垃圾回收详解(重点)
java·jvm·算法
___Dream1 小时前
算法闭关修炼百题计划(八)
算法
学不会lostfound1 小时前
三、计算机视觉_01图像的基本操作
人工智能·opencv·计算机视觉·pil·卷积池化
摆烂仙君2 小时前
《Probing the 3D Awareness of Visual Foundation Models》论文解析——单图像表面重建
人工智能·深度学习·计算机视觉
码农多耕地呗3 小时前
刷别的学校oj—河工大oj1073-1099
开发语言·c++·算法
南宫生3 小时前
力扣-Hot100-二叉树其一【算法学习day.32】
数据结构·学习·算法·leetcode