Effacer les filtres
Effacer les filtres

Why my stable point is not in [0,0]?

2 vues (au cours des 30 derniers jours)
Frantisek Stloukal
Frantisek Stloukal le 29 Avr 2021
Hi, I am trying to plot this phase-time portrait by code I have found here. I don't know why my stable point is not in [0,0] but is shifted to aproximately [11,11]. Any ideas how to repair this problem ? Thanks a lot.
the code:
figure()
%phase-time
[X1,X2] = meshgrid(-5:0.5:5);
xs = arrayfun(@(x,y) {odeFun([],[x,y])}, X1, X2);
x1s = cellfun(@(x) x(1), xs);
x2s = cellfun(@(x) x(2), xs);
quiver(x1s, x2s)
xlabel('x_1')
ylabel('x_2')
axis tight
function dxdt = odeFun(t,x)
global A %pre-difined matrix of autonomous system of ODE's
dxdt(1) = A(1,1)*x(1)+A(1,2)*x(2);
dxdt(2) = A(2,1)*x(1)+A(2,2)*x(2);
end
  2 commentaires
jessupj
jessupj le 29 Avr 2021
Modifié(e) : jessupj le 29 Avr 2021
my guess is that (0,0) corresponds to [X1(11,11),X2(11,11)]. that is, the plot is plotting arrows at locations based on the index of the vectors since you are not telling it what the coordinates are.
try reading the documetnation of quiver to add the location arguments, probably something like
quiver( x1s,x2s, X1, X2)
Frantisek Stloukal
Frantisek Stloukal le 30 Avr 2021
Modifié(e) : Frantisek Stloukal le 30 Avr 2021
I have tried that. The portrait center is now in [0,0] as it should be, although it looks like a distorted banana :D What is interesting is that when equilibrium points are type center or focus it works (when eigen numbers are complex), but when saddle or node it by some reason colaps into this:
PS: thanks for advice

Connectez-vous pour commenter.

Réponse acceptée

Jan
Jan le 30 Avr 2021
Your command for creating the diagram does not get any information about the X and Y coordiantes:
quiver(x1s, x2s)
Then it assume, that the coordinates are going from 1 to the number of elements in each direction.
Provide the X and Y coordinates, if you want so see them:
quiver(X1, X2, x1s, x2s)
Trying to run your code produces an errort message, e.g. due to the missing variable A. So please test this by your own.
  2 commentaires
jessupj
jessupj le 30 Avr 2021
try@Jan's suggestion... mine reversed the position and arrow vectors. ALWAYS read doumentation on matlab functions.
Frantisek Stloukal
Frantisek Stloukal le 2 Mai 2021
Works pretty good for me. Thank you @Jan.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Programming dans Help Center et File Exchange

Produits


Version

R2020b

Community Treasure Hunt

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

Start Hunting!

Translated by