Plot 3D Graph and make level curves

Hi
I have 3 vectors, where:
X is a vector of numbers;
Y is a vector of numbers;
Z is a function that depends on X and Y (i.e)
Z = 4.6597*x.^2 + 2.6897*x.*y - 0.023578*x + 8.1189*y.^2 - 1.9553*y - 1.2304;
I want to plot a 3D curve and I am not succeding. Can someone help me please? Thanks

 采纳的回答

Use the plot3 function.
If you then want it as a 2D plot, use the view function to rotate it.
EDIT — (23 Apr 2021 at 03:17)
I was intending that to use any of the q3D plotting functions, the vectors need to be transformed into matrices first, and then transformed back into vector to use plot3:
X = ...;
Y = ...;
[Xm,Ym] = ndgrid(X,Y);
Zfcn = @(x,y) 4.6597*x.^2 + 2.6897*x.*y - 0.023578*x + 8.1189*y.^2 - 1.9553*y - 1.2304;
Zm = Zfcn(Xm,Ym);
figure
plot3(Xm(:), Ym(:), Zm(:))
grid on
.

8 个评论

Great man, thank you so much.
My pleasure!
I am also trying to use
contour(Xm, Ym, Zm), it worked just fine
But i want to be sure if the Z axis is beeing cutted in points 1, 2, 3, ..., 8.
How can i make sure of that?
And i think it will be better if in figure of contour the ordened pair appears only as a 'x' or 'o', and not the entire line
If you want to specify those contours:
contour(Xm, Ym, Zm, (1:8))
The extra parentheses are not strictly necessay, I added them for clarification.
X = ...;
Y = ...;
[Xm,Ym] = ndgrid(X,Y);
Zfcn = @(x,y) 4.6597*x.^2 + 2.6897*x.*y - 0.023578*x + 8.1189*y.^2 - 1.9553*y - 1.2304;
Zm = Zfcn(Xm,Ym);
figure
contour(Xm, Ym, Zm, (1:8))
axis('equal')
If you want to label the contours:
contour(Xm, Ym, Zm, (1:8), 'ShowText','on')
That worked when I tried it with my own set of vectors.
Hi, im sorry to bother you again, but now i need to make the same plots, but:
X, Y and Z are vector (not function anymore), how do i do that?
I have tried:
X = ...;
Y = ...;
Z = ...;
[Xm,Ym, Zm] = ndgrid(X,Y,Z);
figure
contour(Xm, Ym, Zm, (1:8))
axis('equal')
but its not working
No worries!
Do this instead —
X = ...;
Y = ...;
Z = ...;
xv = linspace(min(X),max(X),numel(X));
yv = linspace(min(Y),max(Y),numel(Y));
[Xm,Ym] = ndgrid(xv,yv);
Zm = griddata(X,Y,Z,Xm,Ym);
figure
contour(Xm, Ym, Zm, (1:8))
axis('equal')
That should work.
.
As always, my pleasure!

请先登录,再进行评论。

更多回答(2 个)

类别

帮助中心File Exchange 中查找有关 Get Started with Curve Fitting Toolbox 的更多信息

产品

版本

R2018a

标签

Community Treasure Hunt

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

Start Hunting!

Translated by