Solve 1D Burgers Equation via Semi-Implicit Adams-Bashforth/Crank-Nicolson Scheme
28 views (last 30 days)
Show older comments
Hello world,
I'm trying to solve the 1D Burgers equation (nonlinear convection-diffusion equation) by applying the explicit Adams-Bashforth scheme to the nonlinear convective term and the implicit Crank-Nicolson scheme to the diffusive term. The equation in dimensionless form is
data:image/s3,"s3://crabby-images/94fd3/94fd3988e9bb016da5195303ef2abe09ff7deb0d" alt=""
where the second term is nonlinear. Dirichlet boundary conditions on
are
, while those Neumann are
.
data:image/s3,"s3://crabby-images/6e510/6e5103920fb127d8fed06cd28f2e9a28c37b0084" alt=""
data:image/s3,"s3://crabby-images/f0045/f004573e0e262d723dc8acc6d2af0308ffcd12f4" alt=""
data:image/s3,"s3://crabby-images/730f7/730f73d26a770f99e12fccf31d32d63bac560f24" alt=""
The exact solution is
data:image/s3,"s3://crabby-images/11fb8/11fb876f09091c01a60a597f273ed8fb5b3d6373" alt=""
so that the initial condition and steady state solutions respectively are
data:image/s3,"s3://crabby-images/2c88e/2c88e00f48ce0c43290b1b2d45a07351cef4487c" alt=""
data:image/s3,"s3://crabby-images/20a03/20a031299b65d1b4c7f12cac307f9a8790f5de20" alt=""
Note that there is a discontinuity in the exact solution at
. To avoid this, we can start the solution at
where
is a small parameter on the order of
or
. Thus, the initial condition becomes
data:image/s3,"s3://crabby-images/b8c9b/b8c9bd6aa662c00cace1c7f74ab4f8b1b5885f08" alt=""
data:image/s3,"s3://crabby-images/1ab89/1ab899cf564f05b01e5b69e4987633276fe4e1f2" alt=""
data:image/s3,"s3://crabby-images/e1bd0/e1bd090912f8426dc5e2bc310db4621d5e6165b0" alt=""
data:image/s3,"s3://crabby-images/1a247/1a24739e2ec643ded899965a250fb0e6e98a148d" alt=""
data:image/s3,"s3://crabby-images/3f203/3f20339c192e061718683a8d029b1d810ace7c85" alt=""
data:image/s3,"s3://crabby-images/53325/53325e2d824d8e3cdd675ed47e9a595b8394af62" alt=""
I wish to construct a solution using 100 spatial steps in
so that
, and 278 time steps in
so that
. This makes the Courant number (convective stability)
where
since
is the maximum velocity at
found by a perturbation of
. Note that there is no restriction on viscous stability here since the plan is to use an implicit method on the diffusion term.
data:image/s3,"s3://crabby-images/6e510/6e5103920fb127d8fed06cd28f2e9a28c37b0084" alt=""
data:image/s3,"s3://crabby-images/a5429/a54295a852f65ee9b6655f17952c3b2efbc572bc" alt=""
data:image/s3,"s3://crabby-images/da606/da60698ee49d0c66f53017fd25c01a6ed79a6a3b" alt=""
data:image/s3,"s3://crabby-images/0e56f/0e56f2212be74e0e9b6eeef29d93ea8fc5e47c4c" alt=""
data:image/s3,"s3://crabby-images/e7937/e79377b8c0b129f13945e711154fa3c2da2a987a" alt=""
data:image/s3,"s3://crabby-images/31d13/31d136cf4b59f3306d9825abf964bcd4afddf08e" alt=""
data:image/s3,"s3://crabby-images/72924/729243c1c72ea4bf152e9250d93d31c9e457fedd" alt=""
data:image/s3,"s3://crabby-images/9a787/9a7870636419467595334a6141a778a354a9054b" alt=""
data:image/s3,"s3://crabby-images/1ab89/1ab899cf564f05b01e5b69e4987633276fe4e1f2" alt=""
I have solved the 1D diffusion equation using the implicit Crank-Nicolson method, I have solved the 1D Burgers equation using the explicit Euler method, and I have solved several ODEs using the explicit two-step Adams-Bashforth method. I think I understand the theory of this problem, and on paper I have written out the time discretized equations, but my skill in MATLAB is novice and I have no idea how to write code that combines these methods to solve a single PDE. Here, since I'm trying to use the Crank-Nicolson method on the diffusive term in the Burgers equation, I suspect that I can just apply my code from the diffusion equation (in conjunction with some unwritten code for the Adams-Bashforth method) to these initial and boundary conditions.
The MATLAB code from my Crank-Nicolson solution to the 1D diffusion equation applied directly to the initial and boundary conditions of the 1D Burgers equation is:
clear all; close all; clc;
% Construct spatial mesh
Nx = 100; % Number of spatial steps
xl = -6; % Left x boundary
xr = 6; % Right x boundary
dx = (xr-xl)/Nx; % Spatial step
x = xl:dx:xr; % x
% Construct temporal mesh
tf = 2; % Final time
dt = 0.0072; % Timestep
Nt = round(tf/dt); % Number of timesteps
t = 0:dt:tf; % t
% Parameters
umax = 15; % Found by a perturbation of t=10^-2
C = umax*dt/dx; % Convective Stability / Courant Number
disp("Courant Number: "+C)
V = dt/(dx*dx); % Viscous Stability / Diffusion Number
disp("Diffusion Number: "+V)
% Define Boundary & Initial Conditions
% Boundary conditions (Dirichlet)
for j = 1:Nt+1 % Loop through all t
u(1,j) = 2; % u(-6,t) = 2
u(Nx+1,j) = -2; % u(6,t) = -2
end
% Initial condition (t = t0, NOT t = 0)
for i = 1:Nx+1 % Loop through all x
u(i,1) = (-2*sinh(x(i)))/(cosh(x(i))-exp(0.0001)); % u(x,t0)
end
% Define the right (MMr) and left (MMl) matrices in the Crank-Nicolson method
aal(1:Nx-2) = -V; % Below the main diagonal in MMl
bbl(1:Nx-1) = 2+2*V; % The main diagonal in MMl
ccl(1:Nx-2) = -V; % Above the main diagonal in MMl
MMl = diag(bbl,0)+diag(aal,-1)+diag(ccl,1); % Building the MMl matrix
aar(1:Nx-2) = V; % Below the main diagonal in MMr
bbr(1:Nx-1) = 2-2*V; % The main diagonal in MMr
ccr(1:Nx-2) = V; % Above the main diagonal in MMr
MMr = diag(bbr,0)+diag(aar,-1)+diag(ccr,1); % Building the MMr matrix
% Implementation of the Crank-Nicholson method
for j = 1:Nt
u(2:Nx,j+1) = inv(MMl)*MMr*u(2:Nx,j);
end
Plotting this solution:
data:image/s3,"s3://crabby-images/81f76/81f76a64ebf34d695f42594445323235de3767ca" alt=""
Clearly this is problematic, but hopefully a good start. In addition to incorporating the Adams-Bashforth scheme, I think I also need to incorporate the Neumann boundary conditions. If anyone out there is familiar with this semi-implicit AB/CN method, I would be very appreciative of some guidance. I know this is an elaborate questions, so please don't hesitate to write comments and communicate with me about anything.
Thank you!
0 Comments
Answers (1)
Mat Hunt
on 14 Jul 2023
Make sure your vaiue of D*dt/dx^2 isn't too large, ideally, it should be around 1.
0 Comments
See Also
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!