如何将点云数据转换为曲面和实体

Author Image

作者Bjorn Sjodin

2021年 1月 28日

在实际仿真过程中,并不是所有分析都是以 CAD 模型开始的。有时,我们唯一可用的数据仅是一系列点数据,也称为点云数据。在这篇博客中,我们将演示如何将点云数据转换为可在 COMSOL Multiphysics®软件中进行仿真分析的几何模型。

什么是点云?

点云是指在xyz坐标上绘制的一系列三维点数据。这些点通常来自使用激光扫描仪、测量工具或雷达成像等技术对物体表面进行扫描所获得的信息。

下面的屏幕截图显示了一个文本文件中的部分点云数据,其中的xyz坐标以制表符分隔列的形式排列。

含点云数据的文本文件
含点云数据的文本文件屏幕截图。

这是 COMSOL Multiphysics 可以导入的最简单的坐标格式类型之一。在软件中,它被称为电子表格格式。在这种格式下,可以使用可选的%(百分比)字符来代表注释行。可以用空格、逗号、分号或制表符分隔值和索引。当这类数据被导入后,软件将根据文件中的行号为其指定坐标的索引。由于没有关于这些点之间的信息(也称为连通性),因此这种点集经常存在歧义。我们用一个简单的二维示例来说明可能发生的歧义类型。以下图中的二维曲线为例,从图中可以明显看出,点 5、18 和 7 是曲线上的连续点。

蓝线代表一条2D曲线,曲线上的连续点标有数字,用于演示如何转换点云数据。
然而,在下图中,由导入的点云数据表示的对应曲线并不是那么明显。也许点 5、6 和 4 是曲线上的连续点?

一个带编号的点,但没有线的点云数据,显示了一条推测的但不明显的二维曲线。
点云数据可能具有内在的歧义。点 5、6 和 4 是不是曲线上连续的点?在这个示例中,它们没有连接,这可以从原始曲线看出,但不能从其相对稀疏的点云数据中看出。

如果一个导入的三维坐标列表带有相关的三角形表面连通性数据,例如 STL,PLY 或 3MF 文件格式,就可以解决这种歧义。比如,一个由两点之间的连通性定义的,并且仅定义了表面的三角形列表。如下所示,三角形表面数据文件

15 17 23

表示将索引为 15、17 和 23 的点作为三角形的顶点相连。

另一方面,如果只有点云数据而没有连通性信息,我们就需要做出其他假设来解决这种歧义。一种可能的假设是:表面数据以z=f(x,y)的形式表示,也称为函数面。如果数据不在该表单z=f(x,y)上,可以尝试将其分成几部分,使每一部分在表单z=f(x,y)上。这里要注意的是,在表单y=f(x,z)或者x=f(y,z)上的数据在重新排列后同样有用。

可视化点云数据

将点坐标数据可视化的一种简单方法是将其作为表格导入到多边形几何对象中,然后使用转换为点操作,如下图所示。

COMSOL Multiphysics UI在图形窗口中以点云数据作为几何点对象的侧面视图。
COMSOL Multiphysics 模型开发器中点云数据的几何点对象的正面视图。

点云数据的可视化图,从两个不同的视角看到的几何点对象。

基于这个视图,可以假设点云数据定义了以z=f(x,y)形式表示的函数面。为了方便以后使用,我们需要知道点云的范围。获取此信息的一种简单方法是右键单击几何节点,然后选择测量

“测量设置”窗口的屏幕截图,展开了“几何类型”、“选择”和“测量”部分。
测量设置窗口给出了有关点云范围的信息。

由点云范围显示的信息可以看到,有 958 个点在xy方向上都从 0.5 延伸到 9.5m,在z方向上从 -0.2 延伸到 +1.5m。本示例中使用的单位是米(m)。

现在,我们可以尝试使用转换为曲面操作将这组点数据转换为曲面。但是,这个操作不起作用。因为我们没有这些点的连接信息,所以系统将提示一条错误消息。我们需要以某种方式构建连接性数据。另外,还需要假设数据在表单z=f(x,y)上。解决方案是将点云作为一个非结构化插值曲面导入。

创建一个插值曲面

接下来,我们在全局定义节点下添加一个插值函数,并将数据源设置为文件。浏览点云文本文件,在本示例中为C\ COMSOL \ point_cloud.txt,如下图所示。您可以点击文章末尾的链接下载此文件。

COMSOL Multiphysics 中的插值设置屏幕截图,展开了定义和插值和外推部分。
由点云定义的插值函数。

插值功能将自动猜测该数据在表单z=f(x,y)上,文件的前两列分别代表xy坐标,第三列代表函数值,即函数曲面的z坐标。我们可以从参数量中看到这一点,它被自动设置为2,分别对应于xy坐标。函数名称被自动设置为int1(可以更改以及文件中的位置被设置为 1 表示int1xy)的函数值,代表z坐标的将由输入参数列之后的第一列给出。换句话说,列数 2+1=3。在这个示例中,文件只有三列,因此 1 是唯一选择。如果数据采用其他形式,则可以在导入之前使用文本编辑器或电子表格软件(例如 Excel®)重新排列数据。

然后,单击插值设置窗口顶部的绘图创建绘图按钮将插值函数可视化。绘图选项将创建一个临时的可视化结果,创建绘图选项将创建一个二维网格数据集,并在结果下的二维绘图组节点创建相关的函数绘图。

一个插值函数,由点云数据生成的以彩色表显示了插值函数绘图
函数设置窗口的屏幕截图,展开了部分数据和表达式。

结果及其相关的设置窗口下以函数绘图的形式显示的插值函数。

那么,软件是如何仅基于假设z=f(x,y)来创建表面的几何表示呢?首先,插值函数在后台创建xy坐标的二维三角形网格,然后将函数值关联到每个点,最后在两个函数值之间进行线性插值。我们可以将这个过程看作在点云上放置一个渔网。请注意,这个三角形网格对用户不可见。在插值和外推部分的插值设置窗口中,可以看到设置插值选项,它默认设置为线性。另一个选项是最近邻插值,它将创建一个分段常数函数插值,在这个示例中没有用。

这部分的另外一个设置是外推。这个功能用于猜测函数定义范围之外的值,定义范围由xy坐标确定。在这个示例中,点云分布在 xy平面的一个圆内。当将数据可视化为函数图时,xy 数据取自一个矩形二维栅格数据集,并且插值函数将以辐射模式分配常数函数值,用于填充圆和矩形之间的空间,以限制点云数据。如下图所示,我们可以从点云数据中识别出圆形迹线。

COMSOL 多物理场图形窗口中插值函数的俯视图,以彩色表的形式显示。
内插函数的俯视图,在定义原始点云迹线的圆形区域之外可以看到外推部分。

软件又是如何将这个插值函数转换为可以进行网格划分和仿真分析的几何表示呢?这是通过使用参数化曲面几何对象完成的,我们将在后面进行介绍。

创建一个参数化曲面

要创建一个基于上述插值函数的几何表面,请根据下图在几何下添加参数化曲面特征。

参数化曲面设置窗口的屏幕截图,其中展开了参数、表达式和高级设置部分。
基于点云插值函数的表面的参数化曲面设置。

在这个设置窗口中,s1s2分别被解释为xy坐标,int1s1s2)解释为z坐标。现在,我们需要使用之前通过测量工具获得的信息。我们将 s1 和 s2 的最小值和最大值设置为比点云数据的测量范围宽一点,以确保不会遗漏任何细节。

在这个示例中,参数化曲面将在两个方向上被定义在 0 到 10 之间,以与测得的 0.5 到 9.5 之间的点云数据进行比较。

在内部,COMSOL 软件用 B 样条表面表示参数化曲面,该 B 样条曲线表面近似于计算以xyz表达式定义的数学表面。 B 样条曲面是分段多项式曲面,所使用的分段多项式的数量由数间接确定。结数越大,分段多项式的数目越多,近似效果越好,但是计算成本更高。B 样条曲面中的结数会自动增加,直到曲面近似值满足相对容差栏中指定的容差或直到达到相对容差栏中最大结数栏指定的结数为止。根据相对于参数化曲面的边界框的空间对角线测量容差。

在这个示例中,我们使用试错法得到相对容差为 5e-4,而最大结数为500。(默认值分别为 1e-5 和 20。)下图显示了生成的曲面。


参数化曲面几何对象。

我们可以在更早的时候就使用这项技术,以同时可视化点云和曲面,如下图所示。


参数化曲面几何对象和点云数据。

要更好地控制表面可视化的细节,可以单击网格节点并创建适当单元大小的网格。下图显示了使用极细化设置的网格。要获得更高的分辨率,请选择用户控制网格选项并设置定制单元大小。

模型开发器图形窗口中显示的网格点云和参数化曲面几何对象。
使用网格将点云数据和参数化曲面几何进行可视化。

修剪表面

在原始点云数据中心有一个圆心在x=5,y=5上,半径为 4.5 的圆形迹线。下图显示了添加一个圆柱体来拟合这些测量点,圆柱体高度位于z方向的最小值和最大值之间。

用一个圆形几何裁剪由点云数据生成的参数曲面几何。
用于修剪表面的圆柱体。

现在,使用交集操作通过选择曲面和圆柱体来修剪表面,如下图所示。

将参数化曲面与圆柱体相交后的模型几何形状。
表面与圆柱相交的结果。

修剪的表面,将点云数据覆盖在灰色几何上作为黑点。
点云数据和修剪的表面。

在两个曲面之间的空间创建实体

要在两个内插曲面之间的空间创建具有圆形迹线的实体,只需重复上述步骤导入第二个曲面即可,如下图所示。

The original parametric surface with another surface above that corresponds to another point cloud.
与第二组点云数据对应的第二个曲面。

然后,创建一个圆柱体来修剪表面,并对所有对象使用转换为实体操作,如下图所示。

COMSOL Multiphysics 中模型开发器的屏幕截图,由一个圆柱体和两个参数化曲面组成的紫色几何。
模型开发器图形窗口的灰色圆柱体几何。

使用圆柱体修剪两个表面。

我们可以使用分割对象分割域操作获得相同的结果。这些操作比转换为实体更复杂,并且允许选择圆柱作为要分割的对象或域。然后,可以选择插值曲面作为用于分割的工具对象。在某些情况下,分割域操作适用性更广,因为它允许从对象中分割选定的域,并且可以选择自动扩展平面、圆柱或球形工具面,当这些平面与要划分的域不相交时。

最后,使用删除实体删除不需要的域,如下图所示。

通过导入点云数据和修剪两个插值曲面得到的实体模型几何。
通过导入和修剪两个插值曲面得到的实体。

现在可以对该实体进行网格剖分,并用于任何类型的仿真。在这种情况下,我们可以创建仅有六面体的扫掠网格,如下图所示。

一个带扫掠网格的圆柱体。
用于圆柱体的扫掠网格。

生成点云数据进行测试

我们可以通过本页底部的链接下载本博客文章中使用的点云数据和文件。如果想生成自己的点云数据,使用任何表面。在下图中,如上例所示,使用了一个参数化曲面,并用圆柱体对其进行了修剪,用于z坐标的表达式为:

z = 0.25 * cos(s1)+ 0.2 * cos(1.5 * s2)* exp(-0.1 * s1 + 0.1 * 0.25 * s2)+ 0.1 * s2

实际上,这是用于生成第一个示例中使用的点云数据的表面。

A parametric surface that was created via a mathematical expression and trimmed via a cylindrical object.
由数学表达式给出并由圆柱对象修剪的参数化曲面。

现在,创建一个网格,然后右键单击网格节点并选择绘图结果下生成一个网格图。接下来,右键单击网格图>网格,然后选择添加要导出的绘图数据。在数据设置窗口中,将1用作表达式。由此导出的常量值将不被使用。选择一个文件名,然后单击窗口顶部的导出将数据写入文件。

A screenshot of the Data Settings window, with the Output section expanded to show the Spreadsheet option for exporting data.
用于以电子表格格式输出数据的输出设置。

如果在文本编辑器或电子表格软件中打开生成的文本文件,则会看到带有注释行和四列的标题。最后一列包含常量表达式1。

屏幕截图显示了在文本文件中导出的模型数据。

在电子表格软件(例如 Excel®)中,我们可以删除第 4 列,然后将文件再次保存为文本文件格式。生成的文件将采用与前面讨论的示例相同的格式。请注意,标题中的前导注释行是可选择项,可以删除。

结束语

这篇博客介绍的技术可用于多种用途。例如,可以导入两个以上的曲面来创建更加复杂的结构;可以使用非圆柱体对象修剪数据;在其他示例中,点云数据可以基于圆柱或球形坐标;可以将以上技术与坐标转换结合使用以生成圆柱或球形面切片。

有关在岩土工程应用中使用插值数据的真实示例,请参阅这篇博客:将地质模型整合到区域尺度的地下水模型中

更多相关示例,请参阅这篇博客:如何基于高程数据模拟不规则形状并构建模型几何

动手尝试:转换点云数据

单击下面的按钮,您可以下载文中使用示例的 MPH 文件和数据文件。您还可以找到一个 MPH 文件,这个文件演示了如何将表达式定义的原始参数平面与点云定义的参数平面进行比较。

Microsoft 和 Excel 是 Microsoft Corporation 在美国和/或其他国家的注册商标或商标。

博客分类


评论 (0)

正在加载...
浏览 COMSOL 博客
Baidu
map