2D and 3D graphs

5 views (last 30 days)
Abdulkarim Almukdad
Abdulkarim Almukdad on 28 Oct 2020
Edited: Abdulkarim Almukdad on 29 Oct 2020
I'm looking for a way to draw the attached data (X,Y,S) as 2D graph with S being the color or as 3D graph that includes (X,Y,S) I have tried the mesh and surf. however, the plot doesn't give much information and the resulted shape is wrong, since the ultimate shape should looks like ( + ). Can anyone please help me with this?
  2 Comments
Jan
Jan on 28 Oct 2020
Please make it as easy as possible to answer your question. Post the code you have already, such that the readers do not have to guess, which code is producing, what you think is wrong.
Abdulkarim Almukdad
Abdulkarim Almukdad on 28 Oct 2020
Edited: Abdulkarim Almukdad on 29 Oct 2020
Sorry for that, please see below the code I have used to assign the variables and to plot. From the below code you will see I have used different plot3D functions but all of them are showing the same mistake (left side is connected somehow with the top and bottom parts) please see attached Figure its exactly what I'm looking for (my output should be close to it). I also have one comment which is I guess the boundary function can fix this issue but I don't know how to do it.
NewTable = readtable('Test1.xlsx');
TTT=NewTable{1:1:end, contains(NewTable.Properties.VariableNames, 't')};
XXX=NewTable{1:1:end, contains(NewTable.Properties.VariableNames, 'X')};
YYY=NewTable{1:1:end, contains(NewTable.Properties.VariableNames, 'Y')};
SSS=NewTable{1:1:end, contains(NewTable.Properties.VariableNames, 'S')};
figure
surface(XXX,YYY,SSS);
figure
surfc(XXX,YYY,SSS);
figure
mesh(XXX,YYY,SSS)
figure
contour(XXX,YYY,SSS)
figure
pcolor(XXX,YYY,SSS)
colorbar
shading interp

Sign in to comment.

Accepted Answer

KSSV
KSSV on 28 Oct 2020
Try this:
num = xlsread("Test1.xlsx") ;
[r,c] = size(num');
n = r/9;
% Arrange the data
A = permute(reshape(num,[c,r/n,n]),[2,1,3]);
A = permute(A,[2 1 3]) ;
% get x,y,s
x = squeeze(A(:,2,:)) ;
y = squeeze(A(:,3,:)) ;
s = squeeze(A(:,6,:)) ;
% do inteprolation and convert to grid
m = 100 ; n = 100 ;
xi = linspace(min(x(:)),max(x(:)),m) ;
yi = linspace(min(y(:)),max(y(:)),n) ;
[X,Y] = meshgrid(xi,yi) ;
S = griddata(x,y,s,X,Y) ;
% Make exact plus sign
idx = boundary(x(:),y(:)) ;
bx = x(idx) ; by = y(idx) ;
idx = inpolygon(X,Y,bx,by) ;
S(~idx) = NaN ;
% plot
pcolor(X,Y,S)
shading interp
colorbar
  4 Comments
Abdulkarim Almukdad
Abdulkarim Almukdad on 29 Oct 2020
I meant before you post your code I was trying to do the same but I couldn't so thanks a lot for your help. actually I have removed the outliers above 500 and the graph now is very close to what I want. the only issue is to eliminate those yello dots in the bottom and left side, better without deleting those data and by editing the graph somehow is possible
KSSV
KSSV on 29 Oct 2020
Read about caxis. You can limit the color values here.....but it will effect the complete plot.

Sign in to comment.

More Answers (0)

Categories

Find more on Specifying Target for Graphics Output in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!