how to play fsolve using for loop

2 次查看(过去 30 天)
i want to solve x1 and x2 about a=0:0.01:2*pi
this is my error code
======================================
clear all; clc
ct=1;l2=2.1; l1=2.5; r=0.7; z=5.5; d=1.2; h=1.8;
for a=0:0.01:2*pi
x(ct)=fsolve(@bicycle,[1,0]);
ct=ct+1;
end
==========================
function F = bicycle(x)
l2=2.1; l1=2.5; r=0.7; z=5.5; d=1.2; h=1.8;
F(1) = l1*sin(x(1))-l2*sin(x(2))-d-r*cos(a);
F(2) = z-l1*cos(x(1))-l2*cos(x(2))-h-r*sin(a);
end
how can i solve x1 and x2?

采纳的回答

Star Strider
Star Strider 2019-5-13
Youi need to pass ‘a’ as a parameter to your ‘bicycle’ function.
Try this:
function F = bicycle(x,a)
l2=2.1; l1=2.5; r=0.7; z=5.5; d=1.2; h=1.8;
F(1) = l1*sin(x(1))-l2*sin(x(2))-d-r*cos(a);
F(2) = z-l1*cos(x(1))-l2*cos(x(2))-h-r*sin(a);
end
l2=2.1; l1=2.5; r=0.7; z=5.5; d=1.2; h=1.8;
a=0:0.01:2*pi;
for ct = 1:numel(a)
x(ct,:)=fsolve(@(x)bicycle(x,a(ct)),[1,0]);
end
figure
plot(a, x)
grid
xlabel('a')
ylabel('Root')
legend('F_1', 'F_2', 'Location','N')
The Plot —
how to play fsolve using for loop - 2019 05 13.png
  3 个评论
Star Strider
Star Strider 2019-5-14
As always, my pleasure!
Thank you.
Daniel Londono Serma
muchas gracias me sirvio mucho el ejemplo para encontrar todas las posiciones de un mecanismo de 4 barras

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 MATLAB 的更多信息

产品


版本

R2019a

Community Treasure Hunt

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

Start Hunting!

Translated by