Skip to article frontmatterSkip to article content

Laplace and Poisson equations

Consider the heat equation ut=uxx+uyyu_t=u_{xx}+u_{yy}. After a long time, the distribution of temperature will stop changing. This steady-state solution must satisfy the PDE uxx+uyy=0u_{xx}+u_{yy}=0, which is our third and final canonical PDE.

The Laplace/Poisson equation is the archetype of an elliptic PDE. All linear, constant-coefficient PDEs with no higher than second derivatives can be classified as either parabolic, hyperbolic, or elliptic. No time variable appears in (13.3.1). Although variable names are arbitrary, elliptic PDEs often do represent systems at steady state.

In order to get a fully specified problem, the Laplace or Poisson equations must be complemented with a boundary condition. Because both xx and yy are spatial variables, this is our first encounter with a boundary condition that is not imposed simply at a pair of points. We consider only the Dirichlet condition u(x,y)=g(x,y)u(x,y)=g(x,y) around the entire boundary.

13.3.1Sylvester equation

With the unknown solution represented by its values U=mtx(u)\mathbf{U}=\mtx(u) on a rectangular grid, and second-derivative finite-difference or spectral differentiation matrices Dxx\mathbf{D}_{xx} and Dyy\mathbf{D}_{yy}, the Poisson equation (13.3.1) becomes the discrete equation

DxxU+UDyyT=F, \mathbf{D}_{xx}\mathbf{U} + \mathbf{U} \mathbf{D}_{yy}^T = \mathbf{F},

where F=mtx(f)\mathbf{F}=\mtx(f). Equation (13.3.2), with an unknown matrix U\mathbf{U} multiplied on the left and right in different terms, is known as a Sylvester equation. We will use a new matrix operation to solve it.

13.3.2Kronecker product

The Kronecker product obeys several natural-looking identities:

13.3.3Poisson as a linear system

We can use (13.3.4) to express the Sylvester form (13.3.2) of the discrete Poisson equation as an ordinary linear system. First, we pad (13.3.2) with identity matrices,

DxxUIy+IxUDyyT=F,\mathbf{D}_{xx}\mathbf{U} \mathbf{I}_{y} + \mathbf{I}_{x} \mathbf{U} \mathbf{D}_{yy}^T = \mathbf{F},

where Ix\mathbf{I}_{x} and Iy\mathbf{I}_{y} are the (m+1)×(m+1)(m+1)\times (m+1) and (n+1)×(n+1)(n+1)\times (n+1) identities, respectively. Upon taking the vec of both sides and applying (13.3.4), we obtain

[(IyDxx)+(DyyIx)]Avec(U)u=vec(F)bAu=b.\begin{split} \underbrace{\bigl[ ({\mathbf{I}_{y}} \otimes {\mathbf{D}_{xx}}) + ({\mathbf{D}_{yy}}\otimes {\mathbf{I}_{x}})\bigr]}_{\mathbf{A}} \, \underbrace{\operatorname{vec}(\mathbf{U})}_{\mathbf{u}} &= \underbrace{\operatorname{vec}(\mathbf{F})}_{\mathbf{b}} \\[1mm] \mathbf{A} \mathbf{u} &= \mathbf{b}. \end{split}

This is in the form of a standard linear system in (m+1)(n+1)(m+1)(n+1) variables.

Boundary conditions of the PDE must yet be applied to modify (13.3.7). As has been our practice for one-dimensional boundary-value problems, we replace the collocation equation for the PDE at each boundary point with an equation that assigns that boundary point its prescribed value. The details are a bit harder to express algebraically in the two-dimensional geometry, though, than in the 1D case.

Say that N=(m+1)(n+1)N=(m+1)(n+1) is the number of entries in the unknown U\mathbf{U}, and let BB be a subset of {1,,N}\{1,\dots,N\} such that iBi\in B if and only if (xi,yi)(x_i,y_i) is on the boundary. Then for each iBi\in B, we want to replace row ii of the system Au=b\mathbf{A}\mathbf{u}=\mathbf{b} with the equation

eiTu=g(xi,yi).%:label: pois2bcrep \mathbf{e}_i^T \mathbf{u} = g(x_i,y_i).

Hence from A\mathbf{A} we should subtract away its iith row and add eiT\mathbf{e}_i^T back in. When this is done for all iBi\in B, the result is the replacement of the relevant rows of A\mathbf{A} with relevant rows of the identity:

A~=AIBA+IB, \tilde{\mathbf{A}} = \mathbf{A} - \mathbf{I}_B\mathbf{A} +\mathbf{I}_B,

where IB\mathbf{I}_B is a matrix with zeros everywhere except for ones at (i,i)(i,i) for all iBi\in B. A similar expression can be derived for the modification of b\mathbf{b}. However, rather than implementing a literal interpretation of (13.3.9), the changes to A\mathbf{A} and b\mathbf{b} are made more easily through logical indexing. A small example is more illuminating than further description.

13.3.4Implementation

Function 13.3.1 is our code to solve the Poisson equation.

We use Demo 13.3.2 as a template: create the linear system, modify it for the boundary conditions, solve it using backslash, and reshape to get a grid function. The matrix is N=(m+1)(n+1)N=(m+1)(n+1) on each side and very sparse, so we take care to use sparse matrices in the code to exploit that structure. There is a small but important change from Demo 13.3.2: the boundary conditions are rescaled to read σu(x,y)=σg(x,y)\sigma u(x,y)=\sigma g(x,y), where σ is the largest element of a row of A\mathbf{A}. This tweak improves the condition number of the final matrix.

13.3.5Accuracy and efficiency

In Function 13.3.1 we used second-order finite differences for the discretization. Let’s simplify the discussion by assuming that m=nm=n. The error in the solution can be expected to be O(n2)O(n^{-2}).

The matrix A\mathbf{A} has size N=O(n2)N=O(n^2). The upper and lower bandwidths of the matrix A\mathbf{A} are both O(n)O(n). It can be shown that the matrix is symmetric and negative definite, so sparse Cholesky factorization can be applied to A-\mathbf{A}, taking O(n2N)=O(n4)O(n^2N)=O(n^4) operations.

As nn increases, the truncation error decreases while the operation count increases. The growth in operations is faster than the corresponding decrease in error, making it costly to get high accuracy. Suppose we have fixed running time TT at our disposal. Then n=O(T1/4)n=O(T^{1/4}), and the convergence is O(1/T)O(1/\sqrt{T}). For example, reduction of the error by a factor of 10 requires 100 times the computational effort.

If we chose a Chebyshev spectral discretization instead, the calculus changes. Provided that the solution is smooth, we expect convergence at a rate KnK^{-n} for some K>1K>1. However, the system matrix is no longer sparse nor symmetric, and solution by LU factorization takes O(N3)=O(n6)O(N^3)=O(n^6) flops. Hence as a function of running time TT, we expect a convergence rate on the order of KT1/6K^{-T^{1/6}}. It’s not simple to compare this directly to the finite-difference case. In the long run, the spectral method will be much more efficient, but if the accuracy requirement is undemanding, second-order finite differences may be faster. For the specific case of Poisson’s equation on a rectangle, there are specialized fast solution methods that are beyond the scope of this discussion.

13.3.6Exercises

  1. ✍ Using general 2×22\times 2 matrices, verify identities 4 and 6 in Theorem 13.3.1.
  1. ✍ Prove that the matrix A\mathbf{A} defined in (13.3.7) is symmetric if Dxx\mathbf{D}_{xx} and Dyy\mathbf{D}_{yy} are symmetric.
  1. ⌨ Use Function 13.3.1 to solve the following problems on [0,1]×[0,1][0,1]\times[0,1] using m=n=50m=n=50. In each case, make a plot of the solution and a plot of the error.

    (a) uxx+uyy=2x2[x2(x1)+(10x6)(y2y)]u_{xx}+u_{yy} = 2x^2[x^2(x-1)+(10x-6)(y^2-y)], with u=0u=0 on the boundary.

    Solution: u(x,y)=x4(1x)y(1y)u(x,y) = x^4(1-x)y(1-y).

    (b) uxx+uyy=(16x2+(14y)2)sinh(4xyx)u_{xx}+u_{yy} = \left(16 x^2 + (1-4 y)^2\right) \sinh (4 x y-x), with u=sinh(4xyx)u=\sinh(4xy-x) on the boundary.

    Solution: u(x,y)=sin(4πx))u(x,y) = \sin(4\pi x)).

    (c) uxx+uyy=(20π2)sin(4πx)cos(2πy)u_{xx}+u_{yy} = -(20\pi^2) \sin (4\pi x) \cos (2\pi y), with u=sin(4πx)cos(2πy)u = \sin (4\pi x) \cos (2\pi y) on the boundary.

    Solution: u(x,y)=sin(4πx)cos(2πy)u(x,y) = \sin (4\pi x) \cos (2\pi y).

  2. ⌨ For each case in Exercise 3, solve the problem using Function 13.3.1 with m=n=20,30,40,,120m=n=20,30,40,\ldots,120. For each numerical solution compute the maximum absolute error on the grid. On a log-log plot, compare the convergence of the error as a function of nn to theoretical second-order accuracy.

  3. ⌨ Copy Function 13.3.1 to a new function named poischeb, and modify it to use a Chebyshev discretization rather than finite differences. For each item in Exercise 3, solve the problem using poischeb for m=n=10,15,20,,40m=n=10,15,20,\ldots,40. For each numerical solution compute the maximum absolute error on the grid. Show the convergence of the error as a function of nn on a log-linear plot.

  4. ⌨ Sometimes boundary conditions are specified using a piecewise definition, with a different formula for each side of the domain. Use Function 13.3.1 with m=n=60m=n=60 to solve the Laplace equation on [0,1]2[0,1]^2 with boundary conditions

    u(0,y)=u(1,y)0,u(x,0)=sin(3πx),u(x,1)=e2x(xx2).u(0,y) = u(1,y) \equiv 0, \quad u(x,0) = \sin(3\pi x), \quad u(x,1) = e^{2x}(x-x^2).

    Make a surface plot of your numerical solution.