Plot u=f(x,y,z) with all discrete data

조회 수: 5 (최근 30일)
Retam Paul
Retam Paul 2023년 1월 13일
답변: Star Strider 2023년 1월 13일
Hi all,
I have four columns of data namely cartesian coordinates (x,y,z) and a variable 'u'. All the four data are DISCRETE points. I want to create a 3D plot to visualise the contours of u using a colorbar. Can anyone help?
Thanks
Retam Paul

채택된 답변

Star Strider
Star Strider 2023년 1월 13일
The (x,y,z) vector data must be converted into a 2D matrix by some sort of computational magic so the contour can be plotted.
One approach —
x = randi( 9,50,1);
y = randi(49,50,1);
z = randi(99,50,1);
u = @(x,y,z) exp(-(x-mean(x)).^2) + exp(-(y-mean(y)).^2) + exp(-(z-mean(z)).^2); % Create 'u(x,y,z)'
[X,Y,Z] = ndgrid(x, y, z); % Create Matrices From The Vectors
U = mean(u(X,Y,Z),3) % Eliminate One Dimension To Create 2D MAatrix
U = 50×50
2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0824 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0013 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.0000 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143 2.7143
figure
contour(U)
colormap(turbo)
colorbar
Another approach would be to plot the contours of each ‘page’ of a 3D matrix in different figures.
How you accomplish this depends on what the vectors are and what you want to do with them.
.

추가 답변 (1개)

Davide Masiello
Davide Masiello 2023년 1월 13일
편집: Davide Masiello 2023년 1월 13일
x = rand(1,100);
y = rand(1,100);
z = rand(1,100);
u = rand(1,100);
scatter3(x,y,z,20,u,'filled')
colorbar

카테고리

Help CenterFile Exchange에서 Contour Plots에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by