Help requested for generating an example for this kind of 3D plot
3 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Hi
Please see the figure attached. I have explored a lot but I have not been able to find options to generate a plot like the one shown. Any example (dummy data) would do perfectly for me. Thanks a lot

0 Kommentare
Antworten (2)
chicken vector
am 21 Apr. 2023
Bearbeitet: chicken vector
am 21 Apr. 2023
You can use surf to generate 3D meshes and inpolygon as binary mask to customise the shape of the base grid.
% Number of grids:
nGrid = 50;
% Get [X, Y, Z] data for the plot:
[X,Y] = meshgrid(-1:1/nGrid:1, -1:1/nGrid:1);
Z = peaks(X,Y);
% Number of star corners:
nVertices = 5;
% Outer vertices:
theta = 2*pi*(1/nVertices:1/nVertices:1);
outerVertices = [cos(theta), sin(theta)];
% Inner vertices:
theta = theta + 2*pi/(nVertices*2);
innerVertices = [cos(theta), sin(theta)]/2;
% Compute mask indeces:
vertices = [outerVertices;innerVertices];
vertices = reshape(vertices(:),[],2);
pointsInsideStar = inpolygon(X, Y, vertices(:,1), vertices(:,2));
% Set Z values to NaN when outside the star:
Z(~pointsInsideStar) = NaN;
% Plot:
surf(X, Y, Z, 'AlphaData', ~isnan(Z), 'EdgeColor', 'k', 'FaceColor', [.5 .5 .5])
% Axes labels:
xlabel('x [\mum]')
ylabel('y [\mum]')
zlabel('Film thickness [\mum]')
Result:

0 Kommentare
Siehe auch
Kategorien
Mehr zu Surface and Mesh Plots finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!