2D and 3D graphs

5 ビュー (過去 30 日間)
Abdulkarim Almukdad
Abdulkarim Almukdad 2020 年 10 月 28 日
編集済み: Abdulkarim Almukdad 2020 年 10 月 29 日
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 件のコメント
Jan
Jan 2020 年 10 月 28 日
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 2020 年 10 月 28 日
編集済み: Abdulkarim Almukdad 2020 年 10 月 29 日
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

サインインしてコメントする。

採用された回答

KSSV
KSSV 2020 年 10 月 28 日
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 件のコメント
Abdulkarim Almukdad
Abdulkarim Almukdad 2020 年 10 月 29 日
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 2020 年 10 月 29 日
Read about caxis. You can limit the color values here.....but it will effect the complete plot.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeSpecifying Target for Graphics Output についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by