In Absolute stability we analyzed time step constraints for the semidiscrete heat equation u′=Dxxu in terms of stability regions and the eigenvalues λj of the matrix. Since all the eigenvalues are negative and real, the one farthest from the origin, at about −4/h2, determines the specific time step restriction. For an explicit method, or any method with a finite intersection with the negative real axis, the conclusion is τ=O(h2).
For the Euler and backward Euler solvers, stability is not the only cause of a severely limited time step. Both methods are first-order accurate, with truncation errors that are O(τ). Since the spatial discretization we chose is second-order accurate, then we should choose τ=O(h2) for accuracy as well as stability.
This calculus changes for second-order IVP solvers. When both time and space are discretized at second order, the total truncation error is O(h2+τ2), so it makes sense to use τ=O(h) for accuracy reasons alone. Therefore, a stability restriction of τ=O(h2) is much more strict.
Problems for which the time step is dictated by stability rather than accuracy are referred to as stiff. Stiffness is not a binary condition but a spectrum. It can arise in nonlinear problems and in problems having nothing to do with diffusion. Except for the mildest instances of stiffness, an implicit time stepping method is the best choice.
Why should the model equation y′=λy of absolute stability have wide relevance? Through diagonalization, it is easily generalized to u′=Au for a constant matrix A. But that is still a severely limited type of problem.
The key to making a connection with absolute stability is to look not at an exact solution but to perturbations of one. Such perturbations always exist in real numerical solutions, such as those due to roundoff error, for example. But if we assume the perturbations are tiny, then we can use linear approximations to describe their evolution. If we conclude from such an approximation that the perturbation may grow without bound, then we must seriously question the value of the numerical solution.
Let’s introduce more precision into the discussion. Suppose that u^(t) is an exact solution that we wish to track, and that a perturbation has pushed us to a nearby solution curve u^(t)+v(t). Substituting this solution into the governing ODE and appealing to a multidimensional Taylor series, we derive
While (11.4.4) is linear, the Jacobian matrix in it is time-dependent, which makes analysis difficult. If a perturbation is introduced at a moment t=t⋆, we freeze the Jacobian there and consider
This equation is of the type we used in Absolute stability to discuss the absolute stability of IVP solvers. This suggests the following.
We have not stated a theorem here because we made several approximations and assumptions along the way that are not trivial to quantify. Nevertheless, if the rule of thumb is violated, we should expect perturbations to the exact solution to grow significantly with time, eventually rendering the numerical solution useless. Note that roundoff error is constantly introducing perturbations, so the rule of thumb applies along the entire trajectory of the numerical solution.
The solution to y′=λy, y(0)=1 is exp(λt). If λ is real, this solution grows or decays by a factor of e at t=1/∣λ∣. If λ=iω is imaginary, then the solution has sines and cosines of frequency ω. A complex λ combines these effects.
A Jacobian matrix with eigenvalues at different orders of magnitude therefore implies multiple time scales that the IVP solver needs to cope with. Say ∣λ1∣≫∣λ2∣. Any explicit integrator will have a bounded stability region and therefore impose a time step restriction proportional to ∣λ1∣−1. Any good adaptive integrator will obey such a restriction naturally to control the error. But to observe the “slow” part of the solution, the simulation must go on for a time on the order of ∣λ2∣−1, which is much longer.
In Demo 11.4.2, for example, you can see a combination of fast changes and slow evolution.
In general, the larger the stability region, the more generous the stability time step restriction will be. In the specific context of a semidiscretization of the heat equation, we observed that the eigenvalues of the Jacobian reached a distance O(h−2) on the negative real axis. Consequently, any stability region that is bounded in the negative real direction will have a τ=O(h2) restriction; only the leading constant will change.
Hence it is desirable in stiff problems generally, and diffusion problems in particular, to have a stability region that is unbounded in at least the negative real direction.
For the heat equation, A(α)-stability for any α>0 suffices for unconditional stability.
An A-stable method has a stability region that includes all eigenvalues having nonpositive real part. In other words, all perturbations which ought to be bounded in time actually are. When an A-stable method is used, time step size can be based on accuracy considerations alone.
Referring to Figure 11.3.1 and Figure 11.3.2, the backward Euler (AM1) and trapezoid (AM2) formulas are the only A-stable methods we have encountered. In fact, more accurate A-stable methods are not easy to come by.
Hence the trapezoid formula is as accurate as we can hope for in the family of A-stable linear multistep methods. The situation with Runge–Kutta methods is a little different, but not a great deal more favorable; we do not go into the details.
✍ Write the mechanical oscillator x′′+cx′+kx=0 as a first-order linear system, u′=Au. Show that if c=k+1, this system is stiff as k→∞.
This exercise is about the IVP u′=cos(t)−200(u−sin(t)), u(0)=0.
(a) ✍ Show that u(t)=sin(t) is the exact solution, and find the linearization about this solution.
(b) ✍ Find the lone eigenvalue of the Jacobian. What other time scale is also relevant in the solution?
(c) ⌨ Use Function 6.7.1 (ab4) to solve the IVP over t∈[0,π/2] with n=800,850,900,…,1200 steps. By comparing to the exact solution, show that the method gets either no accurate digits or at least 11 accurate digits.
In Example 6.3.4 we derived the following system for two pendulums hanging from a rod:
(a) ✍ Use the approximation sin(x)≈x to write the problem as a linear system.
(b) ⌨ Compute the eigenvalues of the linear system with γ=0.1, g/L=1, and k=10d for d=0,1,…,5. How fast does the ratio of largest to smallest eigenvalue (in magnitude) grow, as a function of k?
The equation u′=u2−u3 is a simple model for combustion of a flame ball in microgravity. (This problem is adapted from section 7.9 of Moler (2010).) After “ignition,” the exact solution rapidly approaches 1.
(a) ⌨ Solve the problem with initial condition u(0)=0.001 for 0≤t≤2000, using Function 6.4.2 with n=2000 steps. Plot the solution.
(b) ✍ Find the 1×1 Jacobian of this system, and use it with Figure 11.3.2 to derive an upper bound on the time step of RK4 when u=1.
(c) ⌨ Repeat part (a) with n=200,300,…,1000, and make a table of the error at the final time, assuming the exact solution is 1. How do the results relate to part (b)?
The van der Pol equation is a famous nonlinear oscillator given by
(a) ✍ Write the equation as a first-order system and find its Jacobian.
(b) ✍ Find the eigenvalues of the Jacobian when y=±2 and y′=0.
(c) ⌨ Solve the problem solve with μ=500, y(0)=y′(0)=1, for 0≤t≤2000. Plot y(t) as a function of t.
(d) ⌨ Define M(t) as the minimum (i.e., most negative) real part of the eigenvalues of the Jacobian using the computed solution at time t. Evaluate M for each t=0,2,4,6,…,2000, and plot M(t). Explain how your plot relates to parts (b) and (c).