说明:

本文所用方法都来自于网络查找,本文借鉴了一下其他博主的文章,在他的基础上实现了Alpha Shapes算法。然后写了一个Alpha Shapes演示程序。
Alpha Shapes演示程序下载
https://download.csdn.net/download/qq_42570058/38588253
数据:
1、在空白处鼠标单击可以添加数据。
2、也可以直接点击随机数据按钮,随机生成50个数据点。
3、按住Ctrl+Z可以回撤删除最后添加的点。
参数设置:
演示程序默认设置半径为30,可以拖动滑条设置半径值,滑条范围(0-200)。
点击运行AlphaSphaopes按钮即可进行绘制。

软件使用截图

PCL运行结果

Alpha Shapes算法原理

实现过程:
在有限个离散点集S中,存在N个点,这N个点可以组成N*(N-1)条直线,我们可以通过判断该线段是否为边界线提取边界点。边界线判断方式:设定一个半径R,联合每条线段的端点(P1,P2)画圆(显然这种圆有两个),判定圆内没有其他的点,则判定该线段为边界线,P1,P2为边界点。
具体步骤:
1、 遍历每条边
2、 如果判定P1P2长度大于2R,则跳过。
3、 求圆心坐标(C1,C2)。
4、 判断任何一个圆内部不包含S中其他点,P1,P2为边界点。
圆心求解(一定要用向量求解,其他方法很容易出现Bug)。
1、计算向量v1=P1-P2,线段中点坐标mid,
2、根据两向量垂直等于0,可以求的n,
3、根据三角形垂直定理可以求出C1到线段P1P2的长度h,
4、这样就可以计算出C1,C2坐标C1=mid+nh, C1=mid-nh。

qt中实现的代码
该函数主要在qt中实现,大部分是从第一个参考文章中直接复制而来,我自己添加了记录圆心边界点(排好序)。看懂了就可以自己在pcl中实现,其实只需要把点类型改了,然后写一个两点之间距离计算就可以实现。

//该函数从第一个参考文章中直接复制而来,看懂了就可以自己在pcl中实现
void alphaShapes::process()
{for (int i = 0; i<m_points.size(); i++){// k从i+1开始,减少重复计算for (int k = i + 1; k<m_points.size(); k++){// 跳过距离大于直径的情况if (m_points[i].distanceToPoint(m_points[k])>2 * m_radius)continue;// 两个圆心QVector2D c1, c2;// 线段中点QVector2D center = 0.5*(m_points[i] + m_points[k]);// 方向向量 d = (x,y)QVector2D dir = m_points[i] - m_points[k];// 垂直向量 n = (a,b)  a*dir.x+b*dir.y = 0; a = -(b*dir.y/dir.x)QVector2D normal;normal.setY(5);  // 因为未知数有两个,随便给y附一个值5。 if (dir.x() != 0)normal.setX(-(normal.y()*dir.y()) / dir.x());else     // 如果方向平行于y轴{normal.setX(1);normal.setY(0);}normal.normalize();   // 法向量单位化float len = sqrt(m_radius*m_radius - (0.25*dir.length()*dir.length()));c1 = center + len*normal;c2 = center - len*normal;// b1、b2记录是否在圆C1、C2中找到其他点。bool b1 = false, b2 = false;for (int m = 0; m<m_points.size(); m++){if (m == i || m == k)continue;if (b1 != true && m_points[m].distanceToPoint(c1) < m_radius)b1 = true;if (b2 != true && m_points[m].distanceToPoint(c2) < m_radius)b2 = true;// 如果都有内部点,不必再继续检查了if (b1 == true && b2 == true)break;}MyLine edge;if (b1 != true || b2 != true){edge.p1.setX(m_points[i].x());edge.p1.setY(m_points[i].y());edge.p2.setX(m_points[k].x());edge.p2.setY(m_points[k].y());m_lines.push_back(edge);}if (!b1){MyCircle c;c.c1.setX(c1.x());c.c1.setY(c1.y());c.radius = m_radius;m_circles.push_back(c);}if (!b2){MyCircle c;c.c1.setX(c2.x());c.c1.setY(c2.y());c.radius = m_radius;m_circles.push_back(c);}}}takePoint();//获取边界点
}

参考:
https://ryuzhihao123.blog.csdn.net/article/details/78130511?spm=1001.2101.3001.6650.6&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7Edefault-6.highlightwordscore&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7Edefault-6.highlightwordscore

PCL实现Alpha Shapes算法相关推荐

  1. 平面点云的轮廓线计算-alpha shapes算法原理和实现

    alpha shape算法又称为滚球法,是一种提取边界点的算法.跟凸壳提取相比,alpha shape算法能够了凹包情形,且对多个点云时 能勾勒出多个边界线,这是他的优势. 研究alpha shape ...

  2. alpha shapes提取边界原理及详细步骤

    由Edelsbrunner H提出的alpha shapes算法是一种简单.有效的快速提取边界点算法.其克服了点云边界点形状影响的缺点,可快速准确提取边界点,其原理如下: 如下图所示,对于任意形状的平 ...

  3. 【Gis】Alpha Shapes提取离散点凹边轮廓线(java实现)

    Alpha Shapes算法介绍 计算几何中Alpha Shqpes描述欧氏平面有限点集形状的一组分段线性的简单曲线.Alpha Shqpes可以用来从一堆无序的点集中提取边缘,其本质是滚球法,通过控 ...

  4. PCL点云处理算法目录

    一.点云配准 PCL中的点云配准方法:https://www.sohu.com/a/321034987_715754 点云配准资源汇总:https://mp.weixin.qq.com/s/rj090 ...

  5. Alpha matting算法发展

    一.抠图算法简介 Alpha matting算法研究的是如何将一幅图像中的前景信息和背景信息分离的问题,即抠图.这类问题是数字图像处理与数字图像编辑领域中的一类经典问题,广泛应用于视频编缉与视频分割领 ...

  6. pcl::compute3DCentroid()计算质心算法原理

    质心计算公式 质心指的是质量的中心,认为是物体质量集中于此点的假想点. 通常物体质心坐标PcP_cPc​计算公式如下: Pc=1M∑i=0nmiriP_c = \frac{1}{M} \sum_{i= ...

  7. PCL 改进体元滤波算法

    文章目录 一.简介 二.实现代码 三.实现效果 参考资料 一.简介 这里的思路主要是借鉴了地信中的扫描线方法与PCL中的体元滤波,实现了一种对点云边缘进行提取的方法,同时它也是一种降采样的方式,只不过 ...

  8. PCL下使用区域增长算法进行点云平面分割的实现

    首先求解三维点云的法线和曲率 这里要注意要让法线朝向一致,运用的是视点与法线夹角是锐角的方法 可以看见算法很好的分离了桌面,因为桌面的法线一致性很好,但地面的噪点就比较多了,划分的效果也是不太好 查看 ...

  9. 简单平面点云的内外侧轮廓提取

    原点云如图所示: 外侧轮廓提取用的方法是经纬线扫描法,全轮廓提取的方法是alpha shapes算法(点云边界提取方法总结),从全轮廓中剔除外侧轮廓得到内侧轮廓. alpha shapes算法轮廓提取 ...

最新文章

  1. java并发订单号生成
  2. Java中方法和工作内存的关系_JMM中工作内存和主内存的关系
  3. atm c语言流程图_c语言ATM机程序
  4. 【转】用nohup命令让Linux下程序永远在后台执行
  5. 线段树 洛谷 p1531 I hate it(I hate it too)
  6. exchange 2010申请分配证书服务提示:证书无效,不可用于exchange server
  7. [处理数据的心得][1]--相关矩阵的可视化
  8. FFTW3在VS环境下的安装(亲测)
  9. 【夯实基础】Spring在ssh中的作用
  10. 饥荒联机版服务器重置,饥荒联机版服务器重置世界 | 手游网游页游攻略大全
  11. 如何增加架设传奇服务器,传奇私服架设教程
  12. 恒指2.25日预测及操作建议
  13. 面向对象练习:快递柜代码
  14. 营销大师马斯克又发话了:芯片短缺不要怕,明年有望可解决
  15. 求当前高度=n时,值x=多少?求解题思路
  16. dedecms织梦后台模板layui框架
  17. 《后端从入门到熟悉-序言》
  18. PMBOK(第六版) 学习笔记 ——《第一章 引论》
  19. 浅谈小微企业智能化财务转型
  20. MFC隐藏进程自身(任务管理器不可见,wSysCheck等工具可见)

热门文章

  1. [无私分享]最新网盘资源搜索站点
  2. MATLAB仿真斜坡信号的校正,控制系统仿真matlab第六章习题答案.doc
  3. 计算机80坐标转换经纬度,西安80坐标系(高斯投影)转经纬度(示例代码)
  4. vue 数字金额转大写方法
  5. VPB和OSGGIS安装
  6. 1.3 信号处理函数,创建worker进程
  7. SNN ANN 多模态融合 神经网络发展过程的两个分支
  8. 利用Grapher Script 重复绘图
  9. lbe+android6.0+免root,LBE安全大师|lbe安全大师免root下载v6.1.2482 - 欧普软件下载
  10. gpgpu_CPU与GPGPU