【技术实现步骤摘要】
基于墙约束的房间自动分割方法
[0001]本专利技术属于三维重建与计算机图形学领域,尤其涉及室内点云的房间分割方法。
技术介绍
[0002]如何针对现实世界进行三维描述,实现场景的数字化,目前需求应用越来越广,例如:随着传感器技术的快速发展和大量软件处理工具的出现,点云数据得以普及。点云数据通过大量的三维点集合来实现场景的数字化,能够密集而准确地表示出环境中对象的三维几何形状。
[0003]通常室内空间被定义为由永久性结构元素(如地板、天花板和墙壁)包围的空间,将室内空间细分为有意义的子空间(例如房间、走廊)已经在许多工作中进行了阐述,这些工作应用了多种方法并有不同的目标。由于空间细分提供了更简单的子空间之间的空间关系,因此可以根据这些关系为导航应用生成拓扑表示,详细而准确的拓扑地图可以显著节省获得导航轨迹所需的计算工作量。将平面图恰当地划分成单独的房间单元可能是语义映射或场所分类的一个有价值的部分。同样,人类与机器人的交流也大大受益于关于房间范围的共同概念。另外,房间分割作为室内三维重建任务的关键步骤之一,在AEC(建筑、工程和施工行业)行业中也是一个热烈讨论的话题。
[0004]现有的房间分割方法在处理包含噪声、离群点以及数据缺失等问题的点云时往往难以获得比较理想的分割结果。另外,现有方法分割出来的房间边界存在不平滑和不完整的问题。
技术实现思路
[0005]本专利技术的目的在于提供基于墙约束的房间自动分割方法,以解决上述
技术介绍
中提出的目前现有的房间分割方法在处理包含噪声、离群点 ...
【技术保护点】
【技术特征摘要】
1.基于墙约束的房间自动分割方法,其特征在于,包括以下步骤:步骤一:检测墙中心线;从原始点云中提取墙约束,用以切断房间之间的连接完成初始分割,同时将结果作为构建图的输入,具体包括:A)检测墙线,首先遍历点云中被分类为墙的点云面片并判断其是否与水平面垂直,对于每一个近似垂直于水平面墙面片,使用最小二乘方法将其拟合成平面,然后计算出拟合的墙平面与水平面形成的交线即墙线,该交线即为墙平面在水平面的投影,计算出点云中所有的墙线的集合;B)生成双墙中心线,在原始墙线的集合中搜索成对的双墙,首先判断两个墙线是否平行,然后计算它们之间的距离,距离小于给定的墙厚度阈值时即为成对的双墙,计算出成对的双墙之间的中心线将其作为墙中心线;C)生成外墙中心线,设定外墙的厚度t,则原始墙线W向两侧扩展t/2距离为候选墙中心线的位置,设为L1、L2,对于两个候选墙中心线,分别计算它们与原始墙线围成的矩形范围内包含点云的非空栅格的数量SUM1、SUM2,则外墙中心线的选择遵循以下规则:其中centerline为外墙中心线;步骤二:检测墙中心线;对缺失的墙进行推导,获得鲁棒的墙线集合,具体包括:D)将集合中每一条墙中心线的两个端点标记为自由端点和非自由端点,自由端点和非自由端点按照如下规则进行定义:如果在端点的一定范围内不存在其他墙中心线,即不与其他墙段相邻,为自由端点,反之称之为非自由端点;E)根据墙中心线之间的邻接关系对集合中的墙中心线进行分组,以剔除房间之外的其他墙线的干扰,将检测到的墙中心线集合分为了3组;F)对墙中心线数量大于3的组合,按照一定的策略对组合中的自由端点生成虚拟墙线;假设墙线之间都是彼此垂直的,从自由端点出发,生成该自由端点所在墙中心线的垂线,垂线将与其他包含自由端点的墙中心线所在的直线相交,选择与距离最近的包含自由端点的直线构成的交点作为虚拟墙线的终点;如果不存在这样的墙中心线,则不生成这段虚拟墙线;步骤三:利用墙中心线对点云进行初始分割;具体包括:G)对点云进行栅格化,将包含天花板平面点云的网格标记为已占用,未包含的网格标记为未占用,选取偏移距离范围内的点云作为天花板平面点云,偏移距离设置为低于面积最大的天花板点云面片的高度的0.2m范围;H)去除房间与房间之间相连接的部分,使每个房间成为彼此孤立的区域;以墙中心线为中轴,将其两侧等距范围内的占用网格设置成未占用网格,去除范围的宽度不大于对应位置的墙的厚度使得每个房间区域被未占用网格包围,成为彼此孤立的区域;I)在得到了点云在二维平面的投影之后,将其进一步识别为不同的房间;在生成的二值图像上执行基于标记的分水岭算法,将二值图像分割成不同的区域,每个区域赋予唯一的编号,将图像分割结果赋值给点云,完成对点云的初始标记,遍历图像的所有像素,建立图像标签与房间编号的映射关系,然后以每个像素对应的栅格为单位,将像素值相同的所有栅格内的点标记为同一房间,直至完成对整个点云的标记;
步骤4:基于图切的全局最优分割;具体包括:J)构建图;从墙中心线的集合构造无限长的线的排...
【专利技术属性】
技术研发人员:熊彪,
申请(专利权)人:武汉称象科技有限公司,
类型:发明
国别省市:
还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。