Читать книгу Numerical Methods in Computational Finance - Daniel J. Duffy - Страница 46
2.6 STIFF ODEs
ОглавлениеWe now discuss special classes of ODEs that arise in practice and whose numerical solution demands special attention. These are called stiff systems whose solutions consist of two components; first, the transient solution that decays quickly in time, and second, the steady-state solution that decays slowly. We speak of fast transient and slow transient, respectively. As a first example, let us examine the scalar linear initial value problem:
(2.40)
whose exact solution is given by:
In this case the transient solution is the exponential term, and this decays very fast (especially when the constant a is large) for increasing t. The steady-state solution is a constant, and this is the value of the solution when t is infinity. The transient solution is called the complementary function, and the steady-state solution is called the particular integral (when ), the latter including no arbitrary constant. The stiffness in the above example is caused when the value a is large; in this case traditional finite difference schemes can produce unstable and highly oscillating solutions. One remedy is to define very small time steps. Special finite difference techniques have been developed that remain stable even when the parameter a is large. These are the exponentially fitted schemes, and they have a number of variants. The variant described in Liniger and Willoughby (1970) is motivated by finding a fitting factor for a general initial value problem and is chosen in such a way that it produces an exact solution for a certain model problem. To this end, let us examine the scalar ODE:
(2.41)
and let us approximate it using the Theta method:
where the parameter has not yet been specified. We determine it using the heuristic that this so-called Theta method should be exact for the linear constant-coefficient model problem:
Based on this heuristic and by using the exact solution from (2.43) in scheme (2.42) , we get the value (you should check that this formula is correct; it is a bit of algebra). We get:
(2.44)
Note: this is a different kind of exponential fitting.
We need to determine if this scheme is stable (in some sense). To answer this question, we introduce some concepts.
Definition 2.3 The region of (absolute) stability of a numerical method for an initial value problem is the set of complex values for which all discrete solutions of the model problem (2.43) remain bounded when n approaches infinity.
Definition 2.4 A numerical method is said to be A-stable if its region of stability is the left-half plane, that is:
Returning to the exponentially fitted method, we can check that it is A-stable because for all we have , and this condition can be checked using the scheme (2.42) for the model problem (2.43).
We can generalise the exponential fitting technique to linear and non-linear systems of equations. In the case of a linear system, stiffness is caused by an isolated real negative eigenvalue of the matrix A in the equation:
where and A is a constant matrix with eigenvalues and eigenvectors
The solution of Equation (2.45) is given by:
where are arbitrary constants and is a particular integral. In this case we can employ exponential fitting by fitting the dominant eigenvalues which can be computed by the Power method, for example.
If we assume that the real parts of the eigenvalues are less than zero, we can conclude that the solution tends to the steady-state. Even though this solution is well-behaved the cause of numerical instabilities is the presence of quickly decaying transient components of the solution caused by the dominant eigenvalues of the matrix A in (2.45).
Let us take an example whose matrix has already been given in diagonal form:
The solution of this system is given by:
The solutions decay at different rates, and in the case of the explicit Euler method the inequality:
must be satisfied if the first component of the solution is to remain within the region of absolute stability. Unfortunately, choosing a time step of these proportions will be too small to allow for control over the round-off error in the second component.
In this case we fit the dominant eigenvalue. For variable coefficient systems and non-linear systems, we periodically compute the Jacobian matrix and carry out fitting on it.
The presence of different time scales in ODEs leads to a number of challenges when approximating them using the standard finite difference schemes. In particular, schemes such as explicit and implicit Euler, Crank–Nicolson, and predictor-corrector do not approximate these systems well, unless a prohibitively small time step is used. Let us take the example (Dahlquist and Björck (1974)):
with exact solution:
This is a stiff problem because of the different time scales in the solution. We carried out an experiment using the explicit Euler method, and we had to divide the interval into 1.2 million subintervals in order to achieve accuracy to three decimal places. The implicit Euler and Crank–Nicolson methods are not much better.
Robust ODE solvers for stiff system using the Boost C++ library odeint are discussed in Duffy (2018).