我已经在matlab的轨道传播器上完成了我的工作,现在我试图在主脚本的帮助下模拟轨道。
tspan=[0 :860];
Position and velocity
y0(1,1)= 743322.3616 ;
y0(2,1)= -6346021.219 ;
y0(3,1)= -3394131.349 ;
y0(4,1)= 5142.38067;
y0(5,1)= 4487.44895 ;
y0(6,1)= -7264.00872;
%%%% Mass(kg) /surface(m^2)
m = 217 ; %320;
A = 1.2; %8;
%%%% RK4
h=1;
y = zeros(6, tspan(end)/h);
y(:,1) = y0;
for i=1:1:(tspan(end)/h)
H=sqrt(y(1,i)^2+y(2,i)^2+y(3,i)^2);
k_1 = proiectia(tspan(i), y(:,i), H, m, A, y(4:6, i));
k1=k_1;
k_2 = proiectia(tspan(i)+0.5*h, y(:,i)+0.5*h*k_1, H, m, A, y(4:6, i));
k2=k_2;
k_3 = proiectia((tspan(i)+0.5*h), (y(:,i)+0.5*h*k_2), H, m, A, y(4:6, i));
k3=k_3;
k_4 = proiectia((tspan(i)+h),(y(:,i)+k_3*h), H, m, A, y(4:6, i));
k4=k_4;
y(:,i+1) = (y(:,i) + (1/6)*(k1+2*k2+2*k3+k4)*h);
plot3(y(1,:),y(2,:),y(3,: ));
drawnow
end
轨道被很好地描述但是它一直在绘制从0到点(x,y,z)所在的额外线。在表示所有值之后,来自0的线消失并且它仅保持曲线(轨道)。有没有人有任何想法,为什么它在Runge Kutta循环中从0开始绘制该线?
答案 0 :(得分:1)
您正在绘制包含大量零的向量。因此,绘制的线条终止于(0,0,0)。
尝试不绘制零:
plot3(y(1,1:i+1),y(2,,1:i+1),y(3,,1:i+1));