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!





