2D and 3D graphs

5 vues (au cours des 30 derniers jours)
Abdulkarim Almukdad
Abdulkarim Almukdad le 28 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 commentaires
Jan
Jan le 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 le 28 Oct 2020
Modifié(e) : Abdulkarim Almukdad le 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

Connectez-vous pour commenter.

Réponse acceptée

KSSV
KSSV le 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 commentaires
Abdulkarim Almukdad
Abdulkarim Almukdad le 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 le 29 Oct 2020
Read about caxis. You can limit the color values here.....but it will effect the complete plot.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Specifying Target for Graphics Output dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by