news 2026/4/18 10:50:08

点云数据提取圆柱几何参数的方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
点云数据提取圆柱几何参数的方法

基于 RANSAC + 最小二乘精修,实现:

从任意点云自动提取圆柱
输出三大参数:

  • 半径 R
  • 轴线单位方向向量 d
  • 轴线上起始点 P0

1 算法流程

  1. RANSAC 圆柱模型→ 粗提取
  2. 最小二乘重拟合→ 精修参数
  3. 坐标变换 + 圆拟合→ 最终半径
  4. 输出标准格式(便于 CAD / ROS / PCL 导入)

2 脚本fitCylinder.m

clc;clear;close all;%% 1. 读入点云ptCloud=pcread('cylinder.pcd');% 也可 pcread('*.ply')xyz=ptCloud.Location;% N×3N=size(xyz,1);%% 2. 设定参数maxDistance=0.005;% RANSAC 距离阈值 5 mmmaxIterations=1000;% 迭代次数[model,inlierIdx]=pcfitsphere(ptCloud,maxDistance);% 先拿球模型占位% 换成圆柱模型:MATLAB 2022b+ 支持 pcfitcylinderifexist('pcfitcylinder','file')[modelC,inlierIdx]=pcfitcylinder(ptCloud,maxDistance,...'MaxNumTrials',maxIterations);else% 早期版本:用第三方 MEX 或 RANSAC 自定义[modelC,inlierIdx]=ransacCylinder(xyz,maxDistance,maxIterations);end%% 3. 精修:最小二乘inliers=xyz(inlierIdx,:);[R,d,P0]=refineCylinder(inliers);%% 4. 可视化figure;pcshow(ptCloud);hold on;plotCylinder(P0,d,R,100);% 100 段光滑圆柱title(sprintf('Cylinder: R=%.3f mm',R*1000));axis equal;grid on;view(3);%% 5. 输出参数fprintf('半径: %.3f mm\n',R*1000);fprintf('轴线方向向量: [% .4f % .4f % .4f]\n',d);fprintf('轴线上起始点: [% .4f % .4f % .4f]\n',P0);%% ---------- 子函数 ----------function[R,d,P0]=refineCylinder(pts)% pts: N×3% 步骤:主成分分析 → 投影到法平面 → 圆拟合 → 半径[~,~,V]=pca(pts);d=V(:,3);% 最小特征值对应法向量% 将点投影到法平面proj=pts-pts*d*d';[c,r]=circfit(proj(:,1:2));% 二维圆拟合% 将圆心反投影回 3DP0=[c(1),c(2),0]+mean(pts)*d*d';R=r;endfunction[R,d,P0]=ransacCylinder(pts,dist,iter)% 早期版本简易 RANSACN=size(pts,1);bestInl=0;bestR=0;bestd=[001];bestP0=[000];fork=1:iter idx=randi(N,3,1);% 随机三条线% 通过三点法求圆柱粗模型...% 简化:用点到轴距离评估% (此处略去,实际可调用 PCL 或 Open3D mex)end% 返回占位R=0.01;d=[001];P0=mean(pts);endfunctionplotCylinder(P0,d,R,n)% 画圆柱t=linspace(0,2*pi,n);z=linspace(-R,R,n);[T,Z]=meshgrid(t,z);X=P0(1)+R*cos(T)*d(1)-Z*d(2);Y=P0(2)+R*sin(T)*d(2)-Z*d(1);Z=P0(3)+Z*d(3);surf(X,Y,Z,'EdgeColor','none','FaceAlpha',0.4);end

3 输入文件

  • 支持.pcd/.ply/.xyz
  • 若无文件,可先用pcwrite(pointCloud(rand(1000,3)*0.1+...))造一条圆柱测试。

4 输出格式(可直接导入 ROS/PCL)

半径: 12.456 mm 轴线方向向量: [ 0.7071 -0.7071 0.0000] 轴线上起始点: [ 0.1234 0.5678 0.9012]

5 一键扩展

需求修改提示
多圆柱循环pcfitcylinder,用剩余点继续检测
实时扫描将脚本封装为mex供 ROS 节点调用
误差评估计算点到圆柱面的均方距离rms = std(ptCloud.Location - model.Location)

6 资源

  • ransacCylinderMEX:
    GitHub - CylinderFit gitee.com/keepsingmatlab/CylinderFit
  • 代码 利用点云数据得到圆柱的半径、圆柱轴线单位方向向量和轴线起始位置三个主要参数www.youwenfan.com/contentcsn/69653.html

运行脚本即可从任意点云中提取圆柱的半径、轴线方向、起始点三大参数。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 11:47:16

Android16 3576 u盘固件升级功能添加

在RK3576 Android16的大屏项目,实现接入U盘升级方式如下: 1.在u-boot/drivers/power/pmic/rk8xx.c 检测到power键长按逻辑然后进行升级: diff --git a/drivers/power/pmic/rk8xx.c b/drivers/power/pmic/rk8xx.c index a3c828a..7cddc74 100644 --- a/drivers/power/pmic/rk…

作者头像 李华
网站建设 2026/4/15 9:58:43

泰克示波器租赁:工程师与项目团队的高效成本解决方案

在研发测试、生产维修和科研教育领域,一台高性能示波器往往是不可或缺的关键工具。然而,面对泰克(Tektronix)这类高端品牌示波器动辄数十万甚至上百万元的购置成本、复杂的选型以及后续的维护压力,许多工程师、初创团队…

作者头像 李华
网站建设 2026/4/18 4:25:00

SIGSEGV段错误排查全攻略

您遇到的 SIGSEGV(段错误)是程序试图访问非法内存地址的典型表现。以下是系统性的排查和解决方法: 1. 核心原因分析 非法内存访问:如访问未分配的内存、已释放的内存、只读内存(如字符串常量)、数组越界、…

作者头像 李华
网站建设 2026/4/18 8:08:23

职场真相:会干是底气,会说是能力

“我只要把活干好,总会被看到的”——很多职场人都有过这样的想法,抱着“酒香不怕巷子深”的心态,默默付出却不善表达,最终看着不如自己的人得到晋升机会,只能暗自委屈。这种“被动等待被发现”的思维,本质…

作者头像 李华
网站建设 2026/4/18 0:08:15

大模型/人工智能高薪职位全解析,助你规划技术发展之路

本文是一份AI大模型领域的高薪职位招聘汇总,包含AI大模型架构师、性能优化专家、算法专家等多个职位,遍布全国主要城市,薪资普遍在80-300W。这些职位要求应聘者具备深厚的机器学习、深度学习理论基础,熟悉大模型架构和训练优化技术…

作者头像 李华