Converting function file to Anonomys function.
6 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Given we have the function file
function y = lorenz(t,x,sigma,rho,beta)
% INPUT: t is a a real value indicating time
% x is a column vector of size 3 x 1
% sigma, rho, beta are parameters of the Lorenz
% equations
% OUTPUT: y is a column vector of size 3 x 1 that gives
% the right hand side of the Lorenz equations
y=[0;0;0];
x=x+t;
y(1)=sigma*(x(2)-x(1));
y(2)=x(1)*(rho-x(2))-x(3);
y(3)=x(1)*x(2)-beta*x(3);
end
How can we convert this into a Anonymous function
f = @(t,x) lorenz(t,x,sigma,rho,beta)
??.
6 commentaires
Walter Roberson
le 2 Juin 2015
Please show the complete trace of the "too many input arguments" error.
Stephen23
le 2 Juin 2015
If you are getting an error message please give us the complete message (i.e. all of the red text). We need this to know what is happening.
Also please do not insert empty lines into your code, it makes it difficult to read on this forum.
Réponses (2)
Guillaume
le 1 Juin 2015
If you're asking how to replace the whole code in your lorenz function by an anonymous function, I'm not sure it's a good idea as it's not going to be very readable due to the severe limitations of anonymous functions in matlab.
This would be something like:
f = @(t, x) [sigma*(t+(x(2)-x(1))), (x(1)+t)*(rho-x(2)-t)-x(3)-t, (x(1)+t)*(x(2)+t)-beta*(x(3)+t)];
Keep your function in a file. It's a lot clearer.
1 commentaire
Sean de Wolski
le 2 Juin 2015
Modifié(e) : Sean de Wolski
le 2 Juin 2015
^This
And not just clearer; faster also!
Nobel Mondal
le 1 Juin 2015
Modifié(e) : Nobel Mondal
le 1 Juin 2015
fH = str2func('lorenz');
y = feval(fH,t,x,sigma,rho,beta);
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!