有人在MATLAB中有这个绘图错误吗?

问题描述 投票:0回答:1

我已经完成了在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

enter image description here

轨道被很好地描述,但它不断绘制从0到点(x,y,z)的额外线。在表示所有值之后,来自0的线消失并且它仅保持曲线(轨道)。有没有人有任何想法,为什么它在Runge Kutta循环中从0开始绘制该线?

matlab matlab-figure
1个回答
1
投票

您正在绘制包含大量零的向量。因此,绘制的线终止于(0,0,0)。

尽量不要绘制零:

plot3(y(1,1:i+1),y(2,,1:i+1),y(3,,1:i+1));
© www.soinside.com 2019 - 2024. All rights reserved.