matlab三维凸包,计算凸包 - MATLAB & Simulink - MathWorks 中国

本文介绍了如何使用MATLAB中的convhull和convhulln函数计算二维和三维点集的凸包。通过示例展示了如何获取凸包边界上点的索引,并利用这些索引进行绘图。此外,还讨论了简化凸包表示的方法,以及如何计算高维凸包。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用 convhull 和 convhulln 计算凸包

convhull 和 convhulln 函数取一个点集,输出位于凸包边界上的点的索引。凸包基于点索引的表示法支持绘图,且便于数据访问。下面这些示例说明凸包的计算和表示方式。

第一个示例使用 seamount 数据集的一个二维点集作为 convhull 函数的输入。

加载数据。

load seamount

计算点集的凸包。

K = convhull(x,y);

K 表示绕凸包沿逆时针方向排列的点的索引。

绘制数据及其凸包。

plot(x,y,'.','markersize',12)

xlabel('Longitude')

ylabel('Latitude')

hold on

plot(x(K),y(K),'r')

eee9d875e73781d575abb495c26a01b0.png

给凸包上的点添加点标签,以观察 K 的结构。

[K,A] = convhull(x,y);

convhull 可以计算二维和三维点集的凸包。可以重复使用海底山数据集说明三维凸包的计算。

包含海底山 z 坐标数据仰角。

close(gcf)

K = convhull(x,y,z);

在三维空间中,凸包的边界 K 由三角剖分表示。这是以矩阵格式表示的一组三角面,并有关于点数组的索引。矩阵 K 的每一行表示一个三角形。

由于凸包的边界表示为三角剖分,因此可以使用三角剖分绘图函数 trisurf。

trisurf(K,x,y,z,'Facecolor','cyan')

645ff7c8cfa9cdffe7027afc6825ee85.png

三维凸包约束的体积可由 convhull 选择性返回,语法如下。

[K,V] = convhull(x,y,z);

convhull 函数还提供通过移除对面积或体积无贡献的顶点来简化凸包表示的选项。例如,如果凸包的边界面共线或共面,则可以合并这些面,以给出更精确的表示。下面的示例说明此选项的用法。

[x,y,z] = meshgrid(-2:1:2,-2:1:2,-2:1:2);

x = x(:);

y = y(:);

z = z(:);

K1 = convhull(x,y,z);

subplot(1,2,1)

defaultFaceColor = [0.6875 0.8750 0.8984];

trisurf(K1,x,y,z,'Facecolor',defaultFaceColor)

axis equal

title(sprintf('Convex hull with simplify\nset to false'))

K2 = convhull(x,y,z,'simplify',true);

subplot(1,2,2)

trisurf(K2,x,y,z,'Facecolor',defaultFaceColor)

axis equal

title(sprintf('Convex hull with simplify\nset to true'))

1e2a1c5226c78d093894ed1d7344cb64.png

MATLAB 提供 convhulln 函数来支持更高维凸包和超体积的计算。虽然 convhulln 支持 N 维,但是由于内存需求迅猛增长,对高于十维情况下出现的问题难以应对。

convhull 函数在二维和三维情况下优于 convhulln,因为它更稳定,表现出更佳的性能。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值