news 2026/5/30 13:21:33

IterativeClosestPoints icp配准矩阵

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
IterativeClosestPoints icp配准矩阵

一:主要的知识点

1、说明

本文只是教程内容的一小段,因博客字数限制,故进行拆分。主教程链接:vtk教程——逐行解析官网所有Python示例-CSDN博客

2、知识点纪要

本段代码主要涉及的有①ICP配算法的运用,②运用ICP的配准矩阵


二:代码及注释

import vtkmodules.vtkRenderingOpenGL2 import vtkmodules.vtkInteractionStyle from vtkmodules.vtkCommonCore import vtkPoints from vtkmodules.vtkCommonDataModel import vtkCellArray, vtkPolyData, vtkIterativeClosestPointTransform from vtkmodules.vtkFiltersGeneral import vtkTransformPolyDataFilter # from vtkmodules.vtkFiltersSources import def main(): """ 原文写法 sourcePoints = vtkPoints() sourceVertices = vtkCellArray() sp_id = sourcePoints.InsertNextPoint(1.0, 0.1, 0.0) # 返回为0 sourceVertices.InsertNextCell(1) sourceVertices.InsertCellPoint(sp_id) sp_id = sourcePoints.InsertNextPoint(0.1, 1.1, 0.0) # 返回为1 sourceVertices.InsertNextCell(1) sourceVertices.InsertCellPoint(sp_id) sp_id = sourcePoints.InsertNextPoint(0.0, 0.1, 1.0) # 返回为2 sourceVertices.InsertNextCell(1) sourceVertices.InsertCellPoint(sp_id) source = vtkPolyData() source.SetPoints(sourcePoints) source.SetVerts(sourceVertices) 我觉得这种写法与一般示例的写法出入较大,在这里重写 """ sourcePoints = vtkPoints() sourcePoints.InsertNextPoint(1.0, 0.1, 0.0) sourcePoints.InsertNextPoint(0.1, 1.1, 0.0) sourcePoints.InsertNextPoint(0.0, 0.1, 1.0) sourceCells = vtkCellArray() sourceCells.InsertNextCell(1, [0]) sourceCells.InsertNextCell(1, [1]) sourceCells.InsertNextCell(1, [2]) source = vtkPolyData() source.SetPoints(sourcePoints) source.SetVerts(sourceCells) pointCount = 3 for index in range(pointCount): point = [0, 0, 0] sourcePoints.GetPoint(index, point) print("source point[%s]=%s" % (index, point)) # target_points。目标点位 targetPoints = vtkPoints() targetPoints.InsertNextPoint(1, 0, 0) targetPoints.InsertNextPoint(0, 1, 0) targetPoints.InsertNextPoint(0, 0, 1) targetCells = vtkCellArray() targetCells.InsertNextCell(1, [0]) targetCells.InsertNextCell(1, [1]) targetCells.InsertNextCell(1, [2]) target = vtkPolyData() target.SetPoints(targetPoints) target.SetVerts(targetCells) pointCount = 3 for index in range(pointCount): point = [0, 0, 0] targetPoints.GetPoint(index, point) print("target point[%s]=%s" % (index, point)) # 构建icp icp = vtkIterativeClosestPointTransform() icp.SetSource(source) icp.SetTarget(target) icp.GetLandmarkTransform().SetModeToRigidBody() # 设为刚体,只能旋转和平移,不能缩放 icp.SetMaximumNumberOfIterations(20) # 设置最大迭代次数为20 icp.StartByMatchingCentroidsOn() # 开启ICP算法的质心预匹配步骤,它会在第一次迭代时,先应用一个平移变换,将源点云的质心移动到目标点云的质心位置 icp.Modified() # 通知 VTK 管道,这个对象(icp 变换对象)的参数已被修改 icp.Update() """ vtkTransformPolyDataFilter 将一个 vtkPolyData 数据集应用几何变换,然后生成一个新的、已变换的 vtkPolyData 对象 下面一段代码的含义是指将source乘以ipc得到的4x4配准矩阵 """ icpTransformFilter = vtkTransformPolyDataFilter() icpTransformFilter.SetInputData(source) icpTransformFilter.SetTransform(icp) icpTransformFilter.Update() transformedSource = icpTransformFilter.GetOutput() # ============ display transformed points ============== pointCount = 3 for index in range(pointCount): point = [0, 0, 0] transformedSource.GetPoint(index, point) print("transformed source point[%s]=%s" % (index, point)) if __name__ == '__main__': main()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/28 14:12:08

FaceFusion镜像支持ARM架构吗?Jetson设备运行测试

FaceFusion镜像支持ARM架构吗?Jetson设备运行测试 在智能视觉应用不断向边缘延伸的今天,一个现实问题摆在开发者面前:那些原本依赖高性能服务器运行的人脸替换工具,能否在低功耗、小型化的嵌入式设备上“跑起来”?特别…

作者头像 李华
网站建设 2026/5/28 18:09:46

71、SQL 的现状、未来及相关数据库介绍

SQL 的现状、未来及相关数据库介绍 1. SQL 的重要地位 SQL 在计算机行业中持续发挥着重要作用,并且有望继续作为核心技术存在,主要体现在以下几个方面: - SQL 数据库是全球三大软件供应商(微软、甲骨文和 IBM)的旗舰软件产品。 - 它能在各种计算机系统上运行,从大型机…

作者头像 李华
网站建设 2026/5/29 0:06:02

3步高效调试法:彻底解决Blockly生成Python代码的疑难杂症

3步高效调试法:彻底解决Blockly生成Python代码的疑难杂症 【免费下载链接】blockly The web-based visual programming editor. 项目地址: https://gitcode.com/gh_mirrors/bloc/blockly Blockly可视化编程让编程变得简单直观,但很多用户在使用过…

作者头像 李华
网站建设 2026/5/28 18:09:47

FaceFusion能否用于历史人物复现?纪录片制作新思路

FaceFusion能否用于历史人物复现?纪录片制作新思路 在一部关于民国文人的纪录片中,观众突然看到鲁迅先生站在讲台上,神情肃穆地朗读《狂人日记》——他的眼神、微表情甚至说话时的唇动都极为自然。这不是演员扮演,也不是动画渲染&…

作者头像 李华
网站建设 2026/5/27 22:05:16

Coze智能体开发:Coze Studio快速开始

环境要求 在参考本文安装 Coze Studio 之前,确保您的软硬件环境满足以下要求: 项目说明CPU2 CoreRAM4 GiBDocker提前安装 Docker、Docker Compose,并启动 Docker 服务,详细操作请参考 Docker 文档: * macOS&#xff…

作者头像 李华
网站建设 2026/5/27 20:50:43

DataCap开源数据集成平台快速部署完整指南

DataCap开源数据集成平台快速部署完整指南 【免费下载链接】datacap DataCap 是数据转换、集成和可视化的集成软件。支持多种数据源,文件类型,大数据相关数据库,关系型数据库,NoSQL 数据库等。通过软件可以实现管理多种数据源&…

作者头像 李华