surftri.m
来自「网格划分工具箱」· M 代码 · 共 26 行
M
26 行
function tri=surftri(p,t)
%SURFTRI Find surface triangles from tetrahedra mesh
% TRI=SURFTRI(P,T)
% Copyright (C) 2004-2006 Per-Olof Persson. See COPYRIGHT.TXT for details.
% Form all faces, non-duplicates are surface triangles
faces=[t(:,[1,2,3]);
t(:,[1,2,4]);
t(:,[1,3,4]);
t(:,[2,3,4])];
node4=[t(:,4);t(:,3);t(:,2);t(:,1)];
faces=sort(faces,2);
[foo,ix,jx]=unique(faces,'rows');
vec=histc(jx,1:max(jx));
qx=find(vec==1);
tri=faces(ix(qx),:);
node4=node4(ix(qx));
% Orientation
v1=p(tri(:,2),:)-p(tri(:,1),:);
v2=p(tri(:,3),:)-p(tri(:,1),:);
v3=p(node4,:)-p(tri(:,1),:);
ix=find(dot(cross(v1,v2,2),v3,2)>0);
tri(ix,[2,3])=tri(ix,[3,2]);
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?