我在使用后向差的简单谐波振荡器上增加振荡方面面临麻烦。这是我在Scilab中的代码
function [x] = back(h, tf)
k = 2;
m = 1;
i = 2;
t(i - 1) = 0;
x(i - 1) = 10;
v(i - 1) = 0;
t(i) = t(i - 1) + h
v(i) = v(i - 1) - h * (k / m) * x(i - 1)
while t(i) < tf
t(i + 1) = t(i) + h
x(i + 1) = x(i - 1) - 2 * (k / m) * v(i) * h
i = i + 1
end
plot(t, x, 'b');
endfunction
我不太确定您要达到的目标,数学也不正确。但是假设您要解决以下数值问题:
//coefficients of:
k = 2.;
m = 1.;
// with an initial condition of:
t(1) = 0.;
x(1) = 10.;
v(1) = 0.;
// time paramters:
N = 50;
tf = 10;
h = tf / 50.;
for ii = 2:N
t(ii) = t(ii - 1) + h;
x(ii) = x(ii - 1) - 2 * (k / m) * v(ii - 1) * h
v(ii) = v(ii - 1) - h * (k / m) * x(ii - 1)
disp(x(ii))
end
plot(t, x, 'b');
将导致:
这似乎并不正确,但无论如何。请再次检查数学。
根据您的代码,我认为您尝试实现velocity-Verlet scheme。这是一个带有微分方程\ ddot x =-\ frac {k} {m} x的简单振荡器的实现:
function [x] = back(h, tf)
k = 2;
m = 1;
t = 0:h:tf;
x(1) = 10;
v(1) = 0;
for i=2:length(t)
x(i) = x(i - 1) + v(i - 1)*h - k/m*x(i-1)*h^2/2;
v(i) = v(i - 1) - k/m*(x(i)+x(i-1))*h/2;
end
plot(t, x, 'b');
endfunction
[x] = back(0.01, 10)