I'm trying to model the collisions of a ball and its x and y position over a certain period of time in a 500 by 500 box. Whenever I try to run the script for different time steps(h
), I keep getting the error:
Subscripted assignment dimension mismatch.
global h
h_vector=[0.1 0.01 0.001];
t=0:h:500;
for j=1:length(h_vector)
h=h_vector(j);
[xout2,yout2]=walls_euler_method2e;
xout3(j,:)=xout2;
yout3(j,:)=yout2;
end
xout3;
yout3;
function [xout2,yout2]=walls_euler_method2e
global h
f1=5;%dx/dt
f2=-3;%dy/dt
x(1)=0;
y(1)=0;
t=0:h:500;
r=5;%radius of ball
hit_vertical_wall_left_first=0;
hit_horizontal_wall_down_first=0;
vertical_wall_left=250;
vertical_wall_right=-250;
horizontal_wall_up=250;
horizontal_wall_down=-250;
for i=2:length(t)
x(i)=x(i-1)+h.*f1;
y(i)=y(i-1)+h.*f2;
if x(i)==vertical_wall_left-r
f1=-f1;
hit_vertical_wall_left_first=1;
elseif x(1)==vertical_wall_right+r&&hit_vertical_wall_left_first==1;
f1=-f1;
else
fl=f1;
if y(i)==horizontal_wall_down+r
f2=-f2;
hit_horizontal_wall_down_first=1;
elseif y(i)==horizontal_wall_up-r&&hit_horizontal_wall_down_first==1;
f2=-f2;
else
f2=f2;
end
end
end
xout2=x;
yout2=y;