Solving for theta at different time steps

I have the following equation:
47.9618*theta + 15.9809*sin(2*theta) = 20.780136*t
Given, at time t = 0, theta = 0 radians. I want to find theta value at t = 1 second, 2 seconds, etc.
Could this be automated on matlab?

 Respuesta aceptada

James Tursa
James Tursa el 5 de Jul. de 2017
Editada: James Tursa el 5 de Jul. de 2017
E.g.,
>> t = 0;
>> f = @(theta) 47.9618*theta + 15.9809*sin(2*theta) - 20.780136*t;
>> fzero(f,0)
ans =
0
>> t = 1;
>> f = @(theta) 47.9618*theta + 15.9809*sin(2*theta) - 20.780136*t;
>> fzero(f,0)
ans =
0.2649
>> t = 2;
>> f = @(theta) 47.9618*theta + 15.9809*sin(2*theta) - 20.780136*t;
>> fzero(f,0)
ans =
0.5651

3 comentarios

Lee Quan
Lee Quan el 5 de Jul. de 2017
Editada: Lee Quan el 5 de Jul. de 2017
So for getting results from t = 0 to 10 seconds at once, I could do this:
for t=0:10
f = @(theta)47.9618*theta + 15.9809*sin(2*theta) - 20.780136*t;
fzero(f,0)
end
Awesome! Thanks James!
Lee Quan
Lee Quan el 5 de Jul. de 2017
Could you point me to some resources where the '@' notation is used so that I can familiarize myself with it? The @ part is something I can't find in matlab documentation online.
James Tursa
James Tursa el 5 de Jul. de 2017
Editada: James Tursa el 5 de Jul. de 2017
https://www.mathworks.com/help/matlab/matlab_prog/anonymous-functions.html?searchHighlight=anonymous%20function&s_tid=doc_srchtitle

Iniciar sesión para comentar.

Más respuestas (1)

Walter Roberson
Walter Roberson el 5 de Jul. de 2017
Editada: Walter Roberson el 5 de Jul. de 2017
There is no closed form solution for that. Use fzero or fsolve:
eqn = @(theta,t) 47.9618*theta + 15.9809*sin(2*theta) - 20.780136*t;
for t = 1 : 5
theta0 = randn()
fzero( @(theta) eqn(theta,t), theta0)
end

Categorías

Más información sobre Functions en Centro de ayuda y File Exchange.

Etiquetas

Preguntada:

el 5 de Jul. de 2017

Editada:

el 5 de Jul. de 2017

Community Treasure Hunt

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

Start Hunting!

Translated by