converting vector result into matrices for surf command
显示 更早的评论
Hello,in a program there is feald on aplane shown bellow.
the field data was exports and i am trying to recreate this fiels in matlab.
I have a problem where the exported tablable is show in the attached file ,the resulthas a vector as a result.
in surf command i needthe IMAGEEy result be a matrix
its folding every 24 members.
how can i recreate the photo of the progrm thanks?
I tried the photo shown bellow and it gave me gibrish
rows=(with.zmm==48.394400000000000);
data=with(rows,:);
x=data.xmm(1:24);
y=data.ymm;
y2=y(1:24:240);
z=reshape(data.EyImVm,24,[]);
[yy,xx]=meshgrid(x,y2)
surf(xx',yy',z)

回答(2 个)
filename = 'https://www.mathworks.com/matlabcentral/answers/uploaded_files/1200898/with.txt';
with = readtable(filename);
with.Properties.VariableNames = {'xmm', 'ymm', 'zmm', 'ExReVm', 'ExImVm', 'EyReVm', 'EyImVm', 'EzReVm', 'EzImVm'};
rows = ismembertol(with.zmm,48.394400000000000);
data = with(rows,:);
x = data.xmm(1:24);
y = data.ymm;
y2 = y(1:24:240);
z = reshape(data.EyImVm,24,[]);
[yy, xx] = meshgrid(x, y2);
surf(xx',yy',z)
xlabel('x'); ylabel('y'); zlabel('EyImVm');
I have no idea what you want to plot.
Use the first two column (that correspond to ‘x’ and ‘y’ respectively), the choose whatever other column you want, and use scatter3 to plot them. m There is no need to reshape them.
T1 = readtable('https://www.mathworks.com/matlabcentral/answers/uploaded_files/1200898/with.txt')
x = T1{:,1};
y = T1{:,2};
z = T1{:,3};
Eyv = T1{:,6};
figure
scatter3(x, y, z, 10, z, 'filled')
grid on
colormap(turbo)
view(30,20)
figure
scatter3(x, y, Eyv, 10, Eyv, 'filled')
grid on
colormap(turbo)
view(30,20)
Experiment to get the desired result.
.
6 个评论
fima v
2022-11-21
I am having a problem understanding what you want to do.
Using only the first 24 elements of each vector (corresponding to y=-11.3408) I get these results —
T1 = readtable('https://www.mathworks.com/matlabcentral/answers/uploaded_files/1200898/with.txt')
x = T1{:,1};
y = T1{:,2};
z = T1{:,3};
Eyv = T1{:,6};
Uy = unique(y)
% Uym = buffer(Uy,10)
ixr = 1:24;
figure
scatter3(x(ixr), y(ixr), z(ixr), 15, z(ixr), 'filled')
grid on
colormap(turbo)
view(30,20)
figure
scatter3(x(ixr), y(ixr), Eyv(ixr), 15, Eyv(ixr), 'filled')
grid on
colormap(turbo)
view(30,20)
Creating a plane from it —
yv = linspace(min(y(ixr))-0.01, max(y(ixr))+0.01, 24).';
[X,Y] = ndgrid(x(ixr), yv);
% NaNs = nnz(isfinite(Eyv(ixr)))
Z = griddata(x(ixr), yv, Eyv(ixr), X, Y)
figure
surf(X, Y, Z)
grid on
I am not geting any decent results from this.
.
Walter Roberson
2022-11-21
If you have a 3D cuboid of data (not 2D X and Y and corresponding 2D Z), then you can use slice to visualize along arbitrary planes.
This will not work for the 2D/2D/2D gridded case.
If you had non-gridded vectors of X Y Z where the X Y do not happen to all fall along one plane, then you could potentially griddata() or scatteredInterpolant() to create a 3D volume that you could then slice()
Star Strider
2022-11-22
@Walter Roberson — I'm having a difficult time understanding what is desired here.
Walter Roberson
2022-11-22
A line, maybe? Constant z and constant y over a source that is a grid of data would still leave open the possibility of a line graph, EyImVm vs x ?
Star Strider
2022-11-22
Certainly! Although some sort of scatter plot is at the base of this. The surface — if one exists — evolves from that. I just don’t understand how to get there from the provided data.
类别
在 帮助中心 和 File Exchange 中查找有关 Surface and Mesh Plots 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!





