matlab 上三角,matlab – 如何从3D Delaunay三角剖分中获取三角形

我有一个3D点云的三角测量dt(或者可能是四面体化),我想找到一种从中提取三角形的好方法.注意,我知道如何获得四面体,它的简单dt.ConnectivityList,是否有一种从四面体中获取三角形的有效方法?每个三角形应仅在列表中出现一次.

目前我正在做以下事情 – 但是它很慢:

dt = delaunayTriangulation([X Y Z]);

tetrahedra = dt.ConnectivityList;

tris = cell(1, size(tetrahedra, 1)); % contains indices of tris in a tetra

for tt=1:size(tetrahedra, 1)

vertIds = tetrahedra(tt, :); % vertex indices

vmask = logical([0 1 1 1]);

tris{tt} = [vertIds(circshift(vmask, [0 0 0 0]));

vertIds(circshift(vmask, [1 1 1 1]));

vertIds(circshift(vmask, [2 2 2 2]));

vertIds(circshift(vmask, [3 3 3 3]))];

end

tris = unique(sort(cell2mat(tris'), 2), 'rows');

最佳答案 这是一个矢量化版本:

% take all four subsets of three points from the tets and concatenate

tris2 = [tetrahedra(:,[1 2 3]); tetrahedra(:,[1 2 4]); tetrahedra(:,[1 3 4]); tetrahedra(:, [2 3 4])];

% sort each row

tris2 = sort(tris2, 2);

% eliminate duplicates

tris2 = unique(tris2, 'rows');

我得到100,000个测试点(随机数)

Cellmethod: time=9.870982, numelements = 1344960

Vectmethod: time=1.014797, numelements = 1344960

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值