I have attached a text file with the data I am discussing.
I need to triangulate this data so that I can write the triangulation to an stl file using stlwrite (from the file exchange). The problem is that this sequence produces triangles that are NOT in the plane for seemingly no reason. As can be seen, all of the points are in a circle. How can I triangulate this surface without the wierd out of plane triangles appearing??
>> D = importdata('Endcap.txt');
>> TRI = delaunay(D(:,1),D(:,2),D(:,3));
>> trisurf(TRI,D(:,1),D(:,2),D(:,3))
>> hold on
>> plot3(D(:,1),D(:,2),D(:,3),'*r')
Note that I expected something like this:
>> surf([D(:,1),repmat(mean(D(:,1)),length(D),1)],[D(:,2),repmat(mean(D(:,2)),length(D),1)],[D(:,3),repmat(mean(D(:,3)),length(D),1)])

댓글 수: 3

darova
darova 2019년 12월 5일
try alphaShape for triangulating
David Winthrop
David Winthrop 2019년 12월 5일
편집: David Winthrop 2019년 12월 5일
Thank you but this didn't do the trick.
For example:
>> Du = unique(D,'rows');
>> TRI = alphaShape(Du(:,1),Du(:,2),Du(:,3));
>> trisurf(TRI.Points,Du(:,1),Du(:,2),Du(:,3))
Error using patch
Value must be of numeric type and greater than 1
Error in trisurf (line 91)
h = patch('faces',trids,'vertices',[x(:) y(:) z(:)],'facevertexcdata',c(:),...
I don't have alphaShape
Try
plot(TRI)
see HELP

댓글을 달려면 로그인하십시오.

답변 (0개)

카테고리

도움말 센터File Exchange에서 Delaunay Triangulation에 대해 자세히 알아보기

제품

릴리스

R2019a

태그

질문:

2019년 12월 5일

댓글:

2019년 12월 5일

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by