How to plot gradients ?

 Risposta accettata

Star Strider
Star Strider il 1 Ott 2020

2 voti

14 Commenti

qweasd
qweasd il 1 Ott 2020
Modificato: qweasd il 1 Ott 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 il 1 Ott 2020
Thank you, I will try it.
Star Strider
Star Strider il 1 Ott 2020
My pleasure!
qweasd
qweasd il 2 Ott 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 il 2 Ott 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 il 5 Ott 2020
Modificato: qweasd il 5 Ott 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 il 5 Ott 2020
thank you so much
Star Strider
Star Strider il 5 Ott 2020
As always, my pleasure!
saurav Tiwari
saurav Tiwari il 29 Set 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 il 29 Set 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 il 13 Mar 2022
Modificato: Niklas Kurz il 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!

Accedi per commentare.

Più risposte (0)

Categorie

Community Treasure Hunt

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

Start Hunting!

Translated by