Réponse acceptée

Star Strider
Star Strider le 1 Oct 2020

2 votes

14 commentaires

qweasd
qweasd le 1 Oct 2020
Modifié(e) : qweasd le 1 Oct 2020
thanks, I've seen this page but I still can't do it. I am new in Matlab.
This should get you started:
x = linspace(3, 4, 25);
y = linspace(5, 6, 25);
[X,Y] = meshgrid(x,y);
z = @(x,y) x.^2+y.^5+3*x+4*y;
Z = z(X,Y);
See the documentation section on Anonymous Functions to understand ‘z’.
You can also use ndgrid instead of meshgrid.
It is not a very interesting plot.
qweasd
qweasd le 1 Oct 2020
Thank you, I will try it.
Star Strider
Star Strider le 1 Oct 2020
My pleasure!
qweasd
qweasd le 2 Oct 2020
I've been working on it, but still cant do it. I'm really bad :( If you don't mind, can you share the code?
Star Strider
Star Strider le 2 Oct 2020
You aren’t really bad. You simply need to experiment with it.
The rest of the code is essentially what’s in the documentation example that I linked to, from the gradient call to the end of the example. You only need to make a few small changes to it.
qweasd
qweasd le 5 Oct 2020
Modifié(e) : qweasd le 5 Oct 2020
x = linspace(3, 4, 25);
y = linspace(5, 6, 25);
[X,Y] = meshgrid(x,y);
z = @(x,y) x.^2+y.^5+3*x+4*y;
Z = z(X,Y);
[px,py] = gradient(Z)
figure
contour(x,y,Z)
hold on
quiver(x,y,px,py)
hold off
Like this ?
Like that!
The code I wrote for your problem:
x = linspace(3, 4, 25);
y = linspace(5, 6, 25);
[X,Y] = meshgrid(x,y);
z = @(x,y) x.^2+y.^5+3*x+4*y;
Z = z(X,Y);
[px,py] = gradient(Z);
figure
contour(X,Y,Z)
hold on
quiver(X,Y,px,py)
hold off
They appear to match.
qweasd
qweasd le 5 Oct 2020
thank you so much
Star Strider
Star Strider le 5 Oct 2020
As always, my pleasure!
saurav Tiwari
saurav Tiwari le 29 Sep 2021
x = linspace(3, 4, 25);
y = linspace(5, 6, 25);
[X,Y] = meshgrid(x,y);
z = @(x,y) x.^2+y.^5+3*x+4*y;
Z = z(X,Y);
[px,py] = gradient(Z);
figure
contour(X,Y,Z)
hold on
quiver(X,Y,px,py)
hold off
saurav Tiwari
saurav Tiwari le 29 Sep 2021
it's not working
Yes, it is!
x = linspace(3, 4, 25);
y = linspace(5, 6, 25);
[X,Y] = meshgrid(x,y);
z = @(x,y) x.^2+y.^5+3*x+4*y;
Z = z(X,Y);
[px,py] = gradient(Z);
figure
contour(X,Y,Z)
hold on
quiver(X,Y,px,py)
hold off
.
Niklas Kurz
Niklas Kurz le 13 Mar 2022
Modifié(e) : Niklas Kurz le 13 Mar 2022
I would opt to normalise the Arrows for better scaling:
Norm = sqrt(px.^2+py.^2)
quiver(X,Y,px./Norm,py./Norm,0.5)
Otherwise the code is pretty neat!

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur 2-D and 3-D Plots dans Centre d'aide et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by