Cutting area plot matlab
6 ビュー (過去 30 日間)
古いコメントを表示
I have a given 3D surface plot My problem is drawing an area, f and cutting out exactly this area from the given plot.Please help!
3 件のコメント
採用された回答
darova
2020 年 4 月 13 日
What about this?
clc,clear
% generate surface
r = 0:0.1:5;
t = linspace(0,2*pi,30);
[T,R] = meshgrid(t,r);
Z = 5*sin(R)./R;
[X,Y] = pol2cart(T,R);
% data for cutting
x = [1 3 0.7];
y = [0.2 0.3 3];
z = [1 1.2 1];
ix = convhull(X(:),Y(:)); % boundary of surface
x1 = X(ix(1:end-2)); % vertices of boundary
y1 = Y(ix(1:end-2));
gd1 = [2; length(x1); x1(:); y1(:)]; % surface boundary geometry
gd2 = gd1;
gd2(1:2+2*length(x)) = [2; length(x); x(:); y(:)]; % cutting plane boundary geometry
dl = decsg([gd1 gd2],'P1-P2',char('P1','P2')'); % decomposite geometry
[p,e,t] = initmesh(dl,'hmax',0.5); % create mesh
F = scatteredInterpolant(X(:),Y(:),Z(:));
zz = F(p(1,:),p(2,:)); % calculate Z coordinate for each mesh point
fv.vertices = [p;zz]'; % x y z data
fv.faces = t(1:3,:)'; % connection list of faces
cla
patch(fv,'facecolor','r') % surface
patch(x,y,z,'g') % cutting plane
view(150,45)
axis vis3d
ix = convhull(X(:),Y(:)); % boundary of surface
data:image/s3,"s3://crabby-images/44ec4/44ec4b7f8844745e81da9ad0c37716559ab0ed79" alt=""
9 件のコメント
darova
2020 年 4 月 16 日
I choosed XZ plane to detect if points inside triangle (i used inpolygon)
data:image/s3,"s3://crabby-images/22b86/22b8693634bfdd1a8ba184a189f44d27953718fe" alt=""
Since there are another vertices inside i added Y axis condition:
data:image/s3,"s3://crabby-images/e71d9/e71d94a6889c2da97b5177393a2eb900dd65223d" alt=""
where y1 - triangle verices, y2 - surface vertices
data:image/s3,"s3://crabby-images/93575/93575b0af301a89002edf5630ae6fc435755c5e1" alt=""
Result
data:image/s3,"s3://crabby-images/42b7c/42b7c5115cb0cd60c6dc1209f5e0c37c86f625f5" alt=""
Was not that easy! See attached script
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Surface and Mesh Plots についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!