0

我试图自己模拟一个质量钟摆来训练我的 matlab 技能。我编写了一个没有错误的函数,但是它没有做它应该做的事情。

我想为每个时间步迭代它。我的想法是计算当前的力和由此产生的加速度。速度和位置 s 将是所有先前加速度的总和。但不知何故,它忽略了弹簧和摩擦。

以下参数的结果pendel(80,10,0.2,0.2,2)

function pendel (m,te,k,c,s0)
t = linspace(1,te,100*te);
g = 9.81;
s = zeros(1,length(t));
v = zeros(1,length(t));
a = zeros(1,length(t));

for i = 1:length(t)
    f1 = -m*g;
    f2 = -k*s(i);
    f3 = -v(i)*c;
    a(i) = (f1+f2+f3)/m;
    v(i) = sum(a(1:i));
    s(i) = sum(v(1:i))+s0;
end

subplot(3,1,1);
plot (t,s)
title('Ortsdiagramm')

subplot(3,1,2);
plot(t,v)
title('Geschwindigkeitsdiagramm')

subplot(3,1,3);
plot(t,a)
title('Beschleunigungsdiagramm')

end
4

1 回答 1

0

我现在明白了,对于每次迭代,我都使用了 v(i) 和 s(i) 的当前值,它们为零,因为它们在迭代后得到了新值。我对其进行了调整,以便使用 i-1 条目来计算摩擦力和弹簧力。

于 2022-01-08T00:00:04.683 回答