import data and plat a 3D
Mostrar comentarios más antiguos
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 comentarios
Rik
el 20 de Dic. de 2019
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
el 20 de Dic. de 2019
Respuestas (2)
Rik
el 20 de Dic. de 2019
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 comentarios
Verena Salan
el 20 de Dic. de 2019
Verena Salan
el 20 de Dic. de 2019
Rik
el 20 de Dic. de 2019
The reshape method has the downside that you need to be sure about the orientation of your data. It will also fundamentally break if you don't have a complete grid.
Also note that surf will handle non-uniform spacing of values, it just needs a full grid (which is allowed to contain NaN values).
As to the question of how to get the volume: figure out a way to set the other hill to 0 and then use a 2D integration to find the volume.
Verena Salan
el 2 de En. de 2020
Rik
el 2 de En. de 2020
What have you tried?
Verena Salan
el 6 de En. de 2020
Rik
el 6 de En. de 2020
What have you tried so far?
Verena Salan
el 6 de En. de 2020
Rik
el 6 de En. de 2020
On a conceptual level, what would you do? If you needed to do it on paper, what would your approach be?
ME
el 20 de Dic. de 2019
0 votos
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.
Categorías
Más información sobre Surface and Mesh Plots en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!