How do I access and plot thetadot vs. time from function I have created?
3 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Shlok Pravinbhai Kansara
le 8 Oct 2022
Modifié(e) : Shlok Pravinbhai Kansara
le 8 Oct 2022
function thetadot= oscltr(t,theta)
A= [0 0 0.5 0 0 0; 0.5 0 0 0 0 0.5; 0.5 0.5 0 0 0 0; 0 0.5 0 0 0 0; 0 0 0.5 0 0 0; 0 0 0 0.5 0.5 0]; % edge weight matrix
D= [0.5 0 0 0 0 0; 0 1 0 0 0 0; 0 0 1 0 0 0; 0 0 0 0.5 0 0; 0 0 0 0 0.5 0; 0 0 0 0 0 1]; %Diagonal in-degree matrix
L= D-A; %Laplacian matrix
N=6;
K=50;
wi=[1; 1.1 ;0.9; 0.85; 2; 2.1];
thetadot=wi-(K/N)*L*theta;
end
0 commentaires
Réponse acceptée
Walter Roberson
le 8 Oct 2022
Please see my response at https://www.mathworks.com/matlabcentral/answers/1818985-how-to-work-variables-outside-function#answer_1068360 discussing why it is unlikely that you want to access the internal variables computed by an ode function: such a record would have far too many entries and would also not have entries for most of the time steps.
1 commentaire
Plus de réponses (1)
Ghazwan
le 8 Oct 2022
Modifié(e) : Walter Roberson
le 8 Oct 2022
There are several ways, one of whith would be
Dtheta=diff(theta) %theta = values
Dtime=diff(time) %time = time values.
ThetaDot = Dtheta./Dtime.
plot(Dtheta,time) % you have to be careful in case there is 0/0 somewhere.
2 commentaires
Walter Roberson
le 8 Oct 2022
I recommend using gradient() instead. The timestep for ode45 is typically irregular.
Voir également
Catégories
En savoir plus sur Ordinary Differential Equations dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!