Halcon实现3维点云平面拟合

Halcon实现3维点云平面拟合

go 复制代码
function main()
    WindowHandle = open_window()
    ObjectModel3D = load_3D_model("1.om3")
    ObjectModel3DSelected = remove_noise(ObjectModel3D)
    [X, Y, Z] = extract_coordinates(ObjectModel3DSelected)
    [NX, NY, NZ, C] = fit_plane(X, Y, Z)
    visualize(ObjectModel3DSelected, NX, NY, NZ, C, WindowHandle)

打开并配置窗口

go 复制代码
function open_window()
    dev_open_window(0, 0, 512, 512, 'black', WindowHandle)
    set_display_font(WindowHandle, 14, 'mono', 'true', 'false')
    return WindowHandle

加载3D模型

go 复制代码
function load_3D_model(filename)
    read_object_model_3d(filename, 'm', [], [], ObjectModel3D, Status)
    check_status(Status)
    return ObjectModel3D

去除3D模型中的噪点

go 复制代码
function remove_noise(ObjectModel3D)
    connection_object_model_3d(ObjectModel3D, 'distance_3d', 1, ObjectModel3DConnected)
    select_object_model_3d(ObjectModel3DConnected, 'num_points', 'and', 1000, 99999, ObjectModel3DSelected)
    return ObjectModel3DSelected

提取3D模型的坐标信息

go 复制代码
function extract_coordinates(ObjectModel3D)
    get_object_model_3d_params(ObjectModel3D, 'point_coord_x', X)
    get_object_model_3d_params(ObjectModel3D, 'point_coord_y', Y)
    get_object_model_3d_params(ObjectModel3D, 'point_coord_z', Z)
    return [X, Y, Z]

拟合平面

function fit_plane(X, Y, Z)

计算点的重心

XM = mean(X)

YM = mean(Y)

ZM = mean(Z)

复制代码
# 计算对称矩阵M(A)
DX = X - XM
DY = Y - YM
DZ = Z - ZM
MA11 = sum(DX * DX)
MA22 = sum(DY * DY)
MA33 = sum(DZ * DZ)
MA12 = sum(DX * DY)
MA13 = sum(DX * DZ)
MA23 = sum(DY * DZ)

create_matrix(3, 3, [MA11,MA12,MA13,MA12,MA22,MA23,MA13,MA23,MA33], MatrixID)

# 求取特征值和特征向量
eigenvalues_symmetric_matrix(MatrixID, 'true', EigenvaluesID, EigenvectorsID)

# 获取法向量
get_value_matrix(EigenvectorsID, 0, 0, NX)
get_value_matrix(EigenvectorsID, 1, 0, NY)
get_value_matrix(EigenvectorsID, 2, 0, NZ)

# 计算平面的常数C
C = NX * XM + NY * YM + NZ * ZM
if C < 0.0
    NX = -NX
    NY = -NY
    NZ = -NZ
    C = -C
endif
return [NX, NY, NZ, C]

可视化函数

go 复制代码
# 可视化函数
function visualize(ObjectModel3DSelected, NX, NY, NZ, C, WindowHandle)
    # 设置可视化参数
    VisualizationPlaneSize = 40
    GenParamName = ['lut','color_attrib','light_position','alpha']
    GenParamValue = ['color1','coord_z','0.0 0.0 -0.3 1.0', 0.9]

    # 获取3D对象的主要轴(可选)
    moments_object_model_3d(ObjectModel3DSelected, 'principal_axes', Pose)

    # 生成拟合平面的3D对象模型
    gen_plane_object_model_3d(Pose, [-1,-1,1,1] * VisualizationPlaneSize, [-1,1,1,-1] * VisualizationPlaneSize, IntersectionPlane)

    # 设置可视化窗口的角度和位置
    create_pose(-65, -40, 2400, 150, 0, -60, 'Rp+T', 'gba', 'point', PoseIn)

    # 设置标题和操作说明
    Title = '3D object & fitplane'
    Instructions[0] = 'Rotate: Left button'
    Instructions[1] = 'Zoom: Shift + left button'
    Instructions[2] = 'Move: Ctrl + left button'

    # 在窗口中可视化3D对象和拟合平面
    visualize_object_model_3d(WindowHandle, [ObjectModel3DSelected, IntersectionPlane], [], PoseIn, GenParamName, GenParamValue, Title, [], Instructions, Pose)
end function

状态检查

go 复制代码
function check_status(Status)
    if Status != "OK"
        # Handle the error here
相关推荐
minstbe1 小时前
IC设计私有化AI助手实战:基于Docker+OpenCode+Ollama的数字前端综合增强方案(进阶版)
人工智能·python·语言模型·llama
GinoInterpreter2 小时前
什么是翻译的去中心化?
人工智能·自然语言处理·去中心化·区块链·机器翻译·机器翻译模型·机器翻译引擎
码农小白AI3 小时前
IACheck AI报告文档审核:高端制造合规新助力,保障标准引用报告质量
大数据·人工智能·制造
_YiFei3 小时前
哪个降论文AI率工具最好用?
人工智能·深度学习·神经网络
放下华子我只抽RuiKe53 小时前
机器学习全景指南-直觉篇——基于距离的 K-近邻 (KNN) 算法
人工智能·gpt·算法·机器学习·语言模型·chatgpt·ai编程
kisshuan123963 小时前
[特殊字符]【深度学习】DA3METRIC-LARGE单目深度估计算法详解
人工智能·深度学习·算法
sali-tec3 小时前
C# 基于OpenCv的视觉工作流-章33-Blod分析
图像处理·人工智能·opencv·算法·计算机视觉
老星*3 小时前
Trae-cn一句话安装OpenClaw:AI智能体框架快速部署指南
人工智能·编辑器
昨夜见军贴06164 小时前
IACheck结合AI报告审核:轨道扣件横向阻力检测报告确保无误差
人工智能
Qt学视觉4 小时前
AI2-Paddle环境搭建
c++·人工智能·python·opencv·paddle