i need help with this question

1 view (last 30 days)
dulanga
dulanga on 7 May 2019
Commented: dulanga on 7 May 2019
I am supposed to find the number of timesteps i.e the number of steps taken but my answer is incorrect any inputs on my code will be a major help thanks.Also has the advection equation with the center spaced method used correctly ?
N=200;
x=linspace(-10,10,N);
dx=x(2)-x(1);
c=-0.9;
t=0;
dt=0.2;
timestep=0;
f=@(x)exp(-5*x.^2);
y=f(x)';
figure(1),plot(x,y)
title(['Current time=',num2str(t)])
drawnow
%using centered space
A=eye(N)-(0.5*c*(dt/dx))*((diag(ones(N-1,1),1)-diag(ones(N,1),0)));
while abs(y(end))<0.001 && abs(y(1))<0.001
y=A*y;
t=t+dt;
timestep=timestep+1;
figure(1),cla
plot(x,y)
hold on
plot(x,f(x-c*t),'r')
title(['Current time=',num2str(t)])
drawnow
end
  6 Comments
Torsten
Torsten on 7 May 2019
Edited: Torsten on 7 May 2019
You forgot the parenthesis around the difference of the diag-expressions.
And it must be dt/dx instead of dx/dt.
dulanga
dulanga on 7 May 2019
thanks alot how would u implemnt this Capture.JPG
Capt11ure.JPG
N=1000;
x=linspace(-10,10,N);
dx=x(2)-x(1);
c=2.6;
t=0;
dt=0.2;
timestep=0;
f=@(x)exp(-5*x.^2);
y=f(x)';
figure(1),plot(x,y)
title(['Current time=',num2str(t)])
drawnow
%using lax
A=eye(N)-(0.5*c*(dt/dx))*diag(ones(N-1,1),1)-diag(ones(N-1,1),-1);
while abs(y(end))<0.001 && abs(y(1))<0.001
y=A*y;
t=t+dt;
timestep=timestep+1;
figure(1),cla
plot(x,y)
hold on
plot(x,f(x-c*t),'r')
title(['Current time=',num2str(t)])
drawnow
end

Sign in to comment.

Answers (0)

Tags

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!