import data and plat a 3D

1 回表示 (過去 30 日間)
Verena Salan
Verena Salan 2019 年 12 月 20 日
コメント済み: Rik 2020 年 1 月 6 日
I do have a excel file with 3 columns (x y z). I wanna import them to Matlab, and plot a nice surface Plot.i might have to interpolate?
  2 件のコメント
Rik
Rik 2019 年 12 月 20 日
If it is a full grid of x and y, there will be no need for interpollation. Can you share your actual data, or a functional equivalent?
Verena Salan
Verena Salan 2019 年 12 月 20 日
here are my data

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

回答 (2 件)

Rik
Rik 2019 年 12 月 20 日
No interpollation required, just a conversion to a 2D matrix. You can adapt the syntax of accumarray if you do have any missing values (by default it will fill with 0).
num=xlsread('test1.xlsx');
x=num(:,1);
y=num(:,2);
P=num(:,3);
%find the unique x and y values and use them as indices to fill the Z
[X,~,x_]=unique(x);
[Y,~,y_]=unique(y);
Z=accumarray([x_,y_],P);
[X,Y]=ndgrid(X,Y);
surf(X,Y,Z)
  10 件のコメント
Verena Salan
Verena Salan 2020 年 1 月 6 日
don't know how
Rik
Rik 2020 年 1 月 6 日
On a conceptual level, what would you do? If you needed to do it on paper, what would your approach be?

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


ME
ME 2019 年 12 月 20 日
I think you are correct about the need to interpolate. You could try having a read of the link below - that should give you some good pointers.

カテゴリ

Help Center および File ExchangeSurface and Mesh Plots についてさらに検索

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by