当前位置: 首页 > article >正文

多点法相到曲面展开

这个也是我现在做的一个项目其核心原理就是参考halcon 中的案例做的曲面矫正一、问题一个曲面点云 每个点的法向量目标把曲面“展开”为一个近似平面目标把曲面“展开”为一个近似平面二、核心难点-局部坐标系的建立基础单点点 法向 → 一个坐标系https://blog.csdn.net/weixin_39354845/article/details/159355727?sharetypeblogdetailsharerId159355727sharereferPCsharesourceweixin_39354845spm1011.2480.3001.8118那么点云有500个点的话就有500个局部坐标系那么如何把这500个坐标系连续起来这就需要我们做好坐标系一致性三、算法流程Step 1 点云 法向输入Pi, ni来源结构光重建或 PCL 法向估计Step 2 法向统一非常关键问题n 和 -n 不确定解决构造邻接图kNN传播方向if dot(ni, nj) 0 → nj -nj保证整个曲面法向一致Step 3 构造局部坐标系每个点对每个点zi nixi 任意 ⟂ ziyi zi × xi得到Ri [xi yi zi]Step 4 局部参数化关键目标把3D点映射到2D平面局部投影对每个点ui xi · (Pi - P0)vi yi · (Pi - P0)得到( ui, vi ) → 展开坐标❗问题误差会积累会扭曲四、进阶全局展开E Σ || (Pi - Pj) - R*(ui-uj, vi-vj) ||²本质保持局部几何关系不变常见算法1 LSCM最常用Least Squares Conformal Mapping特点保角角度不变展开自然2 ARAP更高级As-Rigid-As-Possible特点尽量保持局部刚性五、工业流程和Matlab 、PCL测试1. ROI裁剪只取局部曲面 2. PCA → 得到主方向 3. 用主平面作为全局坐标系 4. 所有点投影到这个平面 5. 局部用法向做微调补偿 数学表达 u (P - μ) · e1 v (P - μ) · e2 其中 e1, e2 PCA主方向matlabclc; clear; close all; % 构造曲面 [X,Y] meshgrid(-2:0.2:2, -2:0.2:2); Z 0.5*X.^2 0.2*Y.^2; pts [X(:), Y(:), Z(:)]; % PCA mu mean(pts); Q pts - mu; C cov(Q); [V,D] eig(C); [~, idx] sort(diag(D), descend); V V(:, idx); e1 V(:,1); e2 V(:,2); % 展开 u Q * e1; v Q * e2; % 可视化 figure; subplot(1,2,1); scatter3(pts(:,1), pts(:,2), pts(:,3), .); title(原始曲面); subplot(1,2,2); scatter(u, v, .); title(展开后近似平面); axis equal;PCL流程1. 法向估计 / 输入法向 2. 法向统一方向一致 3. PCA求全局参考平面 4. 构造局部坐标场可选增强 5. 投影到2D展开 6. 可选平滑 / 优化法向量估计pcl::PointCloudpcl::PointXYZ::Ptr cloud(new pcl::PointCloudpcl::PointXYZ); pcl::io::loadPCDFile(input.pcd, *cloud); pcl::NormalEstimationpcl::PointXYZ, pcl::Normal ne; ne.setInputCloud(cloud); pcl::search::KdTreepcl::PointXYZ::Ptr tree(new pcl::search::KdTreepcl::PointXYZ()); ne.setSearchMethod(tree); pcl::PointCloudpcl::Normal::Ptr normals(new pcl::PointCloudpcl::Normal); ne.setKSearch(20); ne.compute(*normals);法向量统一for (size_t i 0; i normals-size(); i) { Eigen::Vector3f ni(normals-points[i].normal_x, normals-points[i].normal_y, normals-points[i].normal_z); // 假设统一朝向相机0,0,1 Eigen::Vector3f view(0,0,1); if (ni.dot(view) 0) ni -ni; normals-points[i].normal_x ni.x(); normals-points[i].normal_y ni.y(); normals-points[i].normal_z ni.z(); }PCA(全局坐标系)Eigen::Vector4f centroid; pcl::compute3DCentroid(*cloud, centroid); Eigen::Matrix3f covariance; pcl::computeCovarianceMatrixNormalized(*cloud, centroid, covariance); Eigen::SelfAdjointEigenSolverEigen::Matrix3f solver(covariance); Eigen::Matrix3f eigenVectors solver.eigenvectors(); // 按特征值排序大→小 Eigen::Vector3f e1 eigenVectors.col(2); Eigen::Vector3f e2 eigenVectors.col(1); Eigen::Vector3f e3 eigenVectors.col(0); // 法向方向构造2D坐标展开核心std::vectorEigen::Vector2f uv_points; for (size_t i 0; i cloud-size(); i) { Eigen::Vector3f p(cloud-points[i].x, cloud-points[i].y, cloud-points[i].z); Eigen::Vector3f q p - centroid.head3(); float u q.dot(e1); float v q.dot(e2); uv_points.emplace_back(u, v); }上面方法只用 PCA全局问题曲率大 → 会拉伸改进局部坐标修正思路PCA → 全局方向法向 → 局部微调局部坐标构造Eigen::Vector3f z normal; Eigen::Vector3f x e1.cross(z).normalized(); Eigen::Vector3f y z.cross(x); 然后 float u q.dot(x); float v q.dot(y);局部更贴合曲面核心认知这一块最重要1 局部 vs 全局法向 → 局部正确PCA → 全局稳定2 展开的本质3D曲面 → 找一个低失真映射 → 2D3 不可能完美曲面展开 ≈ 一定有失真除非是可展曲面比如圆柱

相关文章:

多点法相到曲面展开

这个也是我现在做的一个项目,其核心原理就是参考halcon 中的案例做的曲面矫正 一、问题 一个曲面点云 每个点的法向量 目标: 把曲面“展开”为一个近似平面 目标: 把曲面“展开”为一个近似平面 二、核心难点-局部坐标系的建立 基础 单点&…...

OCR API 实现工业零部件标识智能识别

智能制造升级浪潮下,产线标识识别和质检自动化成为制造企业的核心需求。公有云 API OCR 识别接口适配工业严苛生产环境,可精准识别零部件铭牌、生产日期条码、产品序列号、质检报告单等内容。即便面对油污、模糊、低光照等复杂干扰,识别准确率…...

中国城镇化率与城市化率面板数据集|户籍人口数|Excel可直接分析

🔍 数据简介 本数据集整理了 2000–2019 年全国县级行政区 与 2000–2020 年地级及以上城市 的 城镇化率(常住人口城镇化率) 和 城市化率(户籍/建成区等指标),数据来源于《中国统计年鉴》《中国县域统计年鉴…...

CAE软件市场发展态势及优质代理商——今宏科技实践解析

一、CAE行业发展现状与核心价值在工业数字化研发进程中,CAE(计算机辅助工程)软件已成为助力企业提升核心竞争力的核心支撑要素。目前,国内市场上主流且应用普及的CAE软件,大多来源于国外头部企业,其中德国西…...

QML与UI文件实战对比:从开发到部署的差异解析

1. QML与UI文件本质差异解析 第一次接触Qt开发时,很多人都会困惑:为什么有的界面用.qml文件,有的用.ui文件?这两种文件看起来都是文本格式,用文本编辑器打开都能看到代码,但实际使用起来却天差地别。让我用…...

次元画室数据库课程设计辅助:ER图与系统架构图可视化生成

次元画室数据库课程设计辅助:ER图与系统架构图可视化生成 每次带学生做数据库课程设计,最头疼的环节之一就是“画图”。学生们对实体关系、数据流向的理解,往往停留在抽象的代码和文字描述上。让他们凭空想象一个系统的架构,或者…...

探索西门子SMART200无限动态分期催款程序

西门子SMART200无限动态分期催款程序,含SMART PLC程序,各种触摸屏程序(西门子SMARTLINE,昆仑通泰MCGS,维纶通,步科屏),另有详细的视频解析,D34 很有参考价值。 包含一套密…...

JAVA中数组的定义格式(静态初始化和动态初始化)

在Java中,数组是一种用来存储固定大小的同类型元素的容器。数组一旦被创建,其大小就不能改变(尽管可以通过反射修改,但这样做不推荐)。数组在Java中非常重要,因为它们提供了对数据的组织和管理的方式。 为什么要使用数组容器? 假设我要计算销售部门的员工业绩,以往的方…...

YOLOv8训练踩坑实录:修改Ultralytics库源码,彻底告别自动下载yolov11.pt

YOLOv8训练避坑指南:如何彻底禁用自动下载预训练模型 最近在本地训练YOLOv8模型时,遇到了一个令人头疼的问题:明明指定了本地模型路径,程序却总是自动下载最新版本的预训练权重。经过一番排查,终于找到了根本原因和解…...

RexUniNLU从零开始:DeBERTa中文语义理解系统环境部署全流程

RexUniNLU从零开始:DeBERTa中文语义理解系统环境部署全流程 你是不是遇到过这样的场景?拿到一段中文文本,想快速分析里面的关键信息——比如找出里面的人名、地名,看看句子表达了什么情绪,或者提取出“谁在什么时间做…...

第一次降AI率不知道用什么?比话可能是最适合新手的选择

第一次降AI率不知道用什么?比话可能是最适合新手的选择 “学校说要查AI率,我论文肯定过不了,怎么办?” 收到这类消息的频率最近明显增加了。问的人基本都有一个共同特点:之前从来没用过降AI工具,突然被告知…...

SuperGrok 额度管理全攻略:从查看剩余到永久省额度,一文搞定(附带高ROI Prompt 模板)

最近很多 SuperGrok 用户都遇到这个问题,包括重度 Prompt 玩家,尤其是视频生成和图像生成限额收紧了。这是 xAI 因需求激增做了临时调整,不是 bug 。 当前 SuperGrok 真实限额情况:类型典型额度(滚动窗口)重…...

SpringBoot 内置服务器(Tomcat/Jetty/Undertow)切换

用 SpringBoot 开发时,你可能从没关注过“服务器”这件事——点一下启动,接口就能访问,默认用的是 Tomcat。但实际开发中,不同场景需要不同的服务器:比如追求高性能选 Undertow,追求轻量选 Jetty&#xff0…...

一篇文章入门机器学习与PyTorch张量

机器学习 机器学习常见算法分类 机器学习方式:有监督学习,无监督学习,半监督学习,强化学习。机器学习建模流程 机器学习建模流程:获取数据、数据基本理、特征工程、机器学习(训练模型)、模型评估…...

零代码玩转mPLUG视觉问答:本地图片分析工具部署

零代码玩转mPLUG视觉问答:本地图片分析工具部署 1. 为什么选择本地化视觉问答工具 1.1 解决实际业务痛点的利器 在日常工作中,我们经常遇到需要从图片中提取信息的场景。传统的人工处理方式不仅效率低下,还容易出错。本工具基于mPLUG视觉问…...

Gstreamer中MP4/FLV推流RTP的编码陷阱:为何必须解码再编码?

1. 为什么MP4/FLV直接推流RTP会翻车? 第一次用Gstreamer推MP4文件时我也懵了——明明用.h264原始文件推流很顺利,换成MP4就死活播不出来。后来发现这其实是H.264的两种封装格式在作怪。就像你把同一本书分别装进精装盒和平装盒,虽然内容相同&…...

实测Qwen-Image-Edit-2511:换装效果惊艳,角色一致性太强了

实测Qwen-Image-Edit-2511:换装效果惊艳,角色一致性太强了 标签:Qwen-Image-Edit、AI换装、图像编辑、角色一致性、LoRA模型 1. 效果惊艳:换装前后对比展示 最近测试了Qwen-Image-Edit-2511这个AI图像编辑工具,最让…...

Win10下高效统计代码行数:CLOC工具一键安装与实战指南

1. 为什么开发者需要代码统计工具? 作为一个写过五年项目的程序员,我深刻体会到代码行数统计的重要性。刚开始接手新项目时,第一件事就是摸清代码规模——这就像装修房子前要先量尺寸一样基础。你可能遇到过这种情况:领导突然问&…...

初级运维-系统优化-7

Linux系统优化完全指南 本文档涵盖CentOS/RHEL 7.x系统的常用优化配置,适用于初级运维工程师 目录 编辑器技巧系统命令精讲系统信息查看时间同步管理安全服务配置YUM仓库优化网络与连接优化系统性能优化常用软件安装 一、编辑器技巧 1.1 Vim批量注释 操作步骤&am…...

企业级AI助手搭建:星图平台+Clawdbot,让Qwen3-VL:30B在飞书落地(下篇)

企业级AI助手搭建:星图平台Clawdbot,让Qwen3-VL:30B在飞书落地(下篇) 1. 飞书开放平台:创建企业自建应用 1.1 初始化应用 首先登录飞书开放平台开发者后台: 点击"创建企业自建应用"填写应用名…...

别再只用鼠标点!Blender 3.6.5效率翻倍的键盘流操作指南(拯救你的右手腕)

Blender 3.6.5键盘流操作指南:解放右手的高效建模艺术 刚接触Blender时,我们总是不自觉地依赖鼠标点击菜单和工具栏——这就像用勺子吃牛排,虽然也能完成,但效率低下且容易疲劳。真正的Blender高手往往双手不离键盘,仅…...

AI技术演进的两极:模型“校准”革命与生命“设计”时代

当多模态大模型学会“承认看不清”,而生物学AI开始“编写染色体”,我们见证的不仅是技术进步,更是AI发展路径的根本分岔。这两项突破,一项向内追求可靠,一项向外追求创造,共同定义了AI技术的下一个十年。引…...

“刺头”零件的驯服记:6pin折弯针如何从产线噩梦变成自动化香饽饽

老张在产线摸爬滚打八年,最近总爱拍着新来的小徒弟肩膀念叨:“这6pin折弯针啊,比我家那口子还难伺候!”可不是嘛,这零件长得跟个“钩子精”似的——六个引脚弯弯绕绕,往料斗里一倒,自己就能勾连…...

BH1750FVI光传感器驱动开发与I²C通信实战

1. BH1750FVI数字光强传感器技术解析与嵌入式驱动实践 1.1 传感器核心特性与工程定位 BH1750FVI是由ROHM Semiconductor推出的高精度、低功耗数字环境光传感器(Ambient Light Sensor, ALS),采用IC接口通信,具备16位分辨率&#x…...

解密Qwen3-VL三大黑科技:从MRoPE到DeepStack的进化之路

Qwen3-VL技术演进:从MRoPE到DeepStack的架构革命 1. 多模态模型的进化挑战 在人工智能领域,视觉语言模型(VLM)正经历着从简单感知到复杂推理的范式转变。传统模型往往面临三大核心挑战:长上下文理解能力的局限、跨模态对齐的不足,…...

superpowers

一:简介 Superpowers (https://github.com/obra/superpowers) 是一个为 AI 编程代理(如 Claude Code、Codex、OpenCode)打造的完整软件开发工作流系统。它的核心理念是:通过一套可组合的”技能”&#xff0…...

挖到宝了!这个报表工具让我告别加班,新手也能轻松做出专业报表✨

挖到宝了!这个报表工具让我告别加班,新手也能轻松做出专业报表✨ 家人们谁懂啊!以前做报表真的要被熬疯😭 要么是操作复杂,学习就得学好久,要么是做数据模型要写复杂的SQL,搭报表格式更是调半天…...

学习DHCP服务器

一、基本定义DHCP(Dynamic Host Configuration Protocol 动态主机配置协议)是用于自动为网络设备分配 IP 及网络参数的标准协议,最初定义于 RFC 1541,现已被 RFC 2131 取代。二、架构与端口采用 C/S 客户端 / 服务器 模型传输层协…...

盛思锐SEN66 - 关于环境监测类传感器的久远回忆(跑题)

先说点闲话 :)自己都没有注意到,其实接触盛思锐的产品,有好多年了.那时候,是制作一个给农作物植株测量温湿度的叉状设备,里面封装了大名鼎鼎的SHT20.因为整个电路板,被塑胶外壳完全封印,只留下雪亮的金属探针,所以我们亲切的称呼这个产品"小黑叉"(这充分的体现了我们…...

水墨江南模型C语言基础调用示例:轻量级嵌入式集成探索

水墨江南模型C语言基础调用示例:轻量级嵌入式集成探索 最近在捣鼓一些嵌入式设备上的AI应用,发现很多现成的框架对资源要求太高,动不动就要几百兆内存,这让很多单片机或者低功耗MCU望而却步。正好看到水墨江南这个模型&#xff0…...