Codebase list octave-iso2mesh / lintian-fixes/main surfaceclean.m
lintian-fixes/main

Tree @lintian-fixes/main (Download .tar.gz)

surfaceclean.m @lintian-fixes/mainraw · history · blame

function f=surfaceclean(f,v)
%
% f=surfaceclean(f,v)
%
% remove surface patches that are located inside 
%               the bounding box faces
%
% author: Qianqian Fang, <q.fang at neu.edu>
% date: 2008/04/08
%
% input: 
%      v: surface node list, dimension (nn,3)
%      f: surface face element list, dimension (be,3)  
%
% output:
%      f: faces free of those on the bounding box
%
% -- this function is part of iso2mesh toolbox (http://iso2mesh.sf.net)
%
pos=v;
mi=min(pos);
ma=max(pos);

idx0=find(abs(pos(:,1)-mi(1))<1e-6);
idx1=find(abs(pos(:,1)-ma(1))<1e-6);

idy0=find(abs(pos(:,2)-mi(2))<1e-6);
idy1=find(abs(pos(:,2)-ma(2))<1e-6);

idz0=find(abs(pos(:,3)-mi(3))<1e-6);
idz1=find(abs(pos(:,3)-ma(3))<1e-6);

f=removeedgefaces(f,v,idx0);
f=removeedgefaces(f,v,idx1);
f=removeedgefaces(f,v,idy0);
f=removeedgefaces(f,v,idy1);
f=removeedgefaces(f,v,idz0);
f=removeedgefaces(f,v,idz1);

function f=removeedgefaces(f,v,idx1)
mask=zeros(length(v),1);
mask(idx1)=1;
f(find(sum(mask(f)')==3),:)=[];