Nonstandard finite difference scheme

From HandWiki
Revision as of 20:27, 6 March 2023 by Jworkorg (talk | contribs) (add)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Short description: Set of methods in numerical analysis

Nonstandard finite difference schemes is a general set of methods in numerical analysis that gives numerical solutions to differential equations by constructing a discrete model. The general rules for such schemes are not precisely known.[1][2]

Overview

A finite difference (FD) model of a differential equation (DE) can be formed by simply replacing the derivatives with FD approximations. But this is a naive "translation." If we literally translate from English to Japanese by making a one-to-one correspondence between words, the original meaning is often lost. Similarly the naive FD model of a DE can be very different from the original DE, because the FD model is a difference equation with solutions that may be quite different from solutions of the DE. For a more technical definition see Mickens 2000.[1]

A nonstandard (NS) finite difference model, is a free and more accurate "translation" of a differential equation. For example, a parameter (call it v) in the DE may take another value u in the NS-FD model.

Example

As an example let us model the wave equation,

[math]\displaystyle{ (\partial_t^2-v^2 \partial_x^2 ) \Psi(x,t) = 0 . }[/math]

The naive finite difference model, which we now call the standard (S) FD model is found by approximating the derivatives with FD approximations. The central second order FD approximation of the first derivative is

[math]\displaystyle{ f'(x) \approx \frac{f(x+ \Delta x/2)-f(x- \Delta x/2)}{\Delta x}. }[/math]

Applying the above FD approximation to [math]\displaystyle{ f '(x) }[/math], we can derive the FD approximation for [math]\displaystyle{ f '' (x) }[/math],

[math]\displaystyle{ f''(x) \approx \frac{\text{d}_x^2 f(x)}{\Delta x^2}, }[/math]

where we have introduced the shortcut [math]\displaystyle{ \text{d}_x f(x) = f(x+\Delta x/2) - f(x-\Delta x/2) }[/math] for simplicity such that [math]\displaystyle{ \text{d}_x{}^2 f(x) = f(x+\Delta x) + f(x-\Delta x) -2 f(x) }[/math] which can be check by applying [math]\displaystyle{ \text{d}_x }[/math] on [math]\displaystyle{ f(x) }[/math] twice. Approximating both derivatives in the wave equation, leads to the S-FD model,

[math]\displaystyle{ \left[\text{d}_t^2 - (v \Delta t/\Delta x)^2 \text{d}_x^2 \right] \Psi(x,t) = 0. }[/math]

If you insert the solution [math]\displaystyle{ \phi(x,t) = e^{i (kx -\omega t)} }[/math] of the wave equation (with [math]\displaystyle{ \omega/k = v }[/math])into the S-FD model you find that

[math]\displaystyle{ \left[\text{d}_t^2 - (v \Delta t/\Delta x)^2\text{d}_x^2 \right] \phi(x,t) = \epsilon. }[/math]

In general [math]\displaystyle{ \epsilon \neq 0 }[/math] because the solution of the FD approximation to the wave equation is not the same as the wave equation itself.

To construct a NS-FD model which has the same solution as the wave equation, put a free parameter, call it u, in place of [math]\displaystyle{ v \Delta t/ \Delta x }[/math] and try to find a value of u which makes [math]\displaystyle{ \epsilon = 0 }[/math]. It turns out that this value of u is

[math]\displaystyle{ u = \frac{\sin(\omega \Delta t/2)}{\sin(k \Delta x/2) }. }[/math]

Thus an exact nonstandard finite difference model of the wave equation is

[math]\displaystyle{ \left[ \text{d}_t^2 - (u\Delta t/\Delta x)^2 \text{d}_x^2 \right] \Psi(x,t) =0. }[/math]

Further details and extensions of to two and three dimensions as well as to Maxwell's equations can be found in Cole 2002. [2]

References

  1. 1.0 1.1 Mickens, R.E. (2000). Applications of Non-standard Finite Difference Schemes. World Scientific. 
  2. 2.0 2.1 JB Cole, High Accuracy Yee Algorithm Based on Nonstandard Finite Differences: New Developments and Verifications, IEEE Trans. on Antennas and Propagation, vol. 50, no. 9, pp. 1185-1191 (2002)