1. The Method of Lines¶
e.g. Convection \(\Rightarrow\) combinations of space and time schemes show very different behaviour
Using CD in space for the convection term \(c \partial u / \partial x\):
- FD in time \(\Rightarrow\) unstable
- BD in time \(\Rightarrow\) unconditionally stable
- CD in time \(\Rightarrow\) conditionally stable
Question: What criteria should we impose on a time-discretisation method? Applied to given space-discretisation, so that we obtain a stable and accurate scheme.
1.1. General Method¶
Perform a space discretisation \(\Rightarrow\) system of ODEs And express space discretisation in matrix form (including BCs)
Perform a spectral analysis of the matrix \(\Rightarrow\) eigenvalues
Stability conditions on the space discretisation
- The exact time integrated solution of the system of ODEs should not grow unbounded in time
- The eigenvalues \(\Omega\) of the space discretisation matrix must have a non-positive real part
Select a time integration method for the semi-discretised system (discretised in space not time)
\(\Rightarrow\) stability analysis as a function of eigenvalues \(\Omega\)
Compatibility \(\Rightarrow\) the stability region of the time discretisation must include the whole spectrum \(\Omega\)
1.2. The Method of Lines: Analysis of the Space-Discretised Systems¶
Consider a general conservation law as I.BVP over domain \(\Omega\) with boundary \(\Gamma\):
- I.C. \(u(\mathbf{x},0) = u^0(\mathbf{x})\), \(\mathbf{x} \in \Omega\)
- B.C. \(u(\mathbf{x},t) = g(\mathbf{x},t)\), \(\mathbf{x} \in \Gamma\)
In 1D: discretise flux differential operator:
System of ODES:
Group all mesh points to form a column vector \(\mathbf{u}\) and write a system of ODEs
Where \(\mathbf{S}\) is a matrix representing space discritisation
And \(\mathbf{Q}\) is the contribution from BCs
In the FVM formulation, the RHS is the “residual”
This is the “Method of Lines”
1.3. Example 1 - Diffusion¶
CD in space:
To get complete matrix \(S\), we need BCs
1.3.1. Dirichlet BCs¶
Domain \((0, L)\) with \(N\) mesh points (0 and N-1 are the BCs)
B.C. \(u(0,t) = a\) and \(u(L,t) = b\)
i = 1 (a occurs at i=0)
i = N-2 (b occurs at i=N-1)
Finally:
1.3.2. Neumann BCs¶
\({\partial u \over \partial x} = a\) at \(x = 0\) and \(u_N = u(L,t) = b\)
The Neumann BC needs to be discretised using a one-sided difference
i = 0:
i = 1:
Finally (we don’t know \(u_0\) anymore, but we have substituted for it at i=1)
1.3.3. Importance of BCs for stability¶
- The form of \(\mathbf{S}\) depends on BCs
- The eigenvalues depend on \(\mathbf{S}\)
- The stability depends on the eigenvalues
Hence, the stability depends on the BCs
1.3.4. Periodic BCs¶
We must solve all the way to the boundaries, and set any values outside the domain to be equal to the values inside the domain at the opposite end of the domain
\(u_N = u_0\) and \(u_{-1} = u_{N-1}\)
In this case, write an equation for i = 0:
For i = N-1:
\(\mathbf{S}\) similar to the case with Dirichlet BCs, but with 1 in upper right and lower left corners.
Typical for periodic matrices
1.4. Example 2 - Convection¶
with \(a \gt 0\)
1.4.1. Upwind¶
Upwind for interior points:
B.C. \(u(0,t) = g(t)\) at the left boundary
i = 1 (first internal point)
i = N-1 (at the right boundary)
Note: no additional boundary condition is needed at the right boundary (because we are using backward differencing, or upwind)
Finally:
Question: What would happen if we imposed a boundary condition at: \(u_{N-1} = g(t)\)
The last equation would be:
This is decoupled from the data at \(i = N-1\)
No way to ensure that a numerical condition at \(u_0\) will lead to a downstream value that satisfies \(u_{N-1} = g(t)\). Problem is not well-posed
For a > 0
The value at A, \(u_0\) must be specified at i=0. The corresponding value at B will be part of the solution, following the characteristic \(dx/dt = a\)
Any other BC at x=L would be incompatible with \(u_0\) at A.
1.4.2. Central space discretisation with periodic BCs¶
Assume:
\(u_N = u_0\) and \(u_{-1} = u_{N-1}\)
i = 0:
i = N-1:
Finally: