Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

An Alternating Direction Explicit (ADE) Scheme For Time-Dependent Evolution Equations

Download as pdf or txt
Download as pdf or txt
You are on page 1of 21

An Alternating Direction Explicit (ADE) Scheme for

Time-Dependent Evolution Equations


Shingyu Leung and Stanley Osher

June 9, 2005
Abstract
We propose an explicit finite difference scheme to solve nonlinear time-dependent
equations. While applying to linear equations, this scheme is proven to be second or-
der accurate in time and unconditionally stable for arbitrary time step size. Unlike the
Crank-Nicloson scheme or other implicit schemes, however, this scheme can easily be im-
plemented for a wide range of equations. We will give numerical examples to demonstrate
the simplicity and the computational efficiency of the method.

1 Introduction
Time-dependent evolution equations are important in modeling many physical phenom-
ena. When there is an evolution of some physical property, denoted by T (t, x), one can
model the change in this quantity by the following evolution equation,

T (t, x)
= L[T (t, x)] , (1)
t
with some differential operator L. For simple cases when this operator is linear, the
resulting time-dependent evolution equations can be solved relatively easily. Over the
years, there have been a large number of schemes proposed [16].
On the other hand, for nonlinear operator L, it is still not clear how to solve the
resulting nonlinear evolution equation efficiently. One possible way is to follow a similar
approach to linear cases. Using the idea of method of line, we can first discretize the
operator L and get a system of ODE,
dT
= A(T )T , (2)
dt
where A(T ) is a nonlinear operator involving T , and T = (T1 , T2 , . . . , TN )T with Ti =
T (xi ).
Different ways to treat the term A(T )T yield different numerical methods. The sim-
plest one is the explicit scheme, which discretizes the equation in this way

T n+1 = [I + t A(T n )]T n , (3)

where I is the identity operator. As is well-known, such an explicit scheme makes for ease
in programming with a code for an explicit scheme usually containing only a few lines
even for high dimension problems. However, there is a trade-off in computational time
coming from the stability requirement. Inherited from the explicit scheme for solving the
equations with linear L, this explicit scheme for nonlinear equation also has a stability

Department of Mathematics, UCLA, Los Angeles, CA 90095-1555. Email: syleung@math.ucla.edu

Department of Mathematics, UCLA, Los Angeles, CA 90095-1555. Email: sjo@math.ucla.edu

1
An ADE Scheme for Time-Dependent Evolution Equations 2

condition on the time step size one can use. In many cases, this condition could be
relatively restrictive and this could make the method impractical.
One way to relax this stability restriction is to use the method of regularization,
sometimes called the method of precondition. In [15], the author has proposed stabilizing
the evolution equation by adding and subtracting a Laplacian operator. For example, it
is possible to introduce a new operator by rewriting the evolution equation as
T (t, x)
= T + L(T ) , (4)
t
with L = L . This modified equation could then be solved by
Tin+1 Tin
= (T n+1 + T n ) + L(T n ) . (5)
t 2
One advantage of doing these manipulations is that the resulting numerical scheme is
unconditionally stable for arbitrary time step size. This idea may also be applied to
a wide range of nonlinear evolution equations. However, the main drawback of this
approach is that it is not clear how to relate the parameter and the nonlinear operator
L.
Other than regularization, the time step restriction may also be relaxed by using
implicit, or semi-implicit, schemes. The most-used representatives from this class are
motivated by applying the backward Euler scheme or the Trapezoidal rule in time. The
schemes are given by
T n+1 = [I t A(T n )]1 T n , (6)
and (Crank-Nicloson)
1
n+1 t n t
T = I A(T ) I+ A(T ) T n .
n
(7)
2 2
Even though these numerical schemes are unconditionally stable, in many cases, espe-
cially in high dimensional problems, it is not trivial how to invert the operator (I A)
computationally efficiently.
There are two general approaches to invert the operator (I A). The first group uses
Multiplicative Operator Splitting (MOS) methods. A common feature of these methods
is splitting the complicated operator into a product of some simple operators, so that
each of these operators can easily be inverted. Mathematically, we approximate equation
(2) by
YK
T n+1 = [I tAk (T n )]1 T n . (8)
k=1
The second group of methods is called Additive Operator Splitting (AOS) methods
[17, 2, 10]. The idea is to split the operator (I t A) into a summation, rather than
multiplication as in MOS, of some simple operators. Mathematically, we have
K
n+1 1 X 1
T = [I tAk (T n )] T n . (9)
m
k=1

There are a few advantages of using AOS schemes over MOS schemes. Perhaps the most
important one is that we can easily apply parallel computing. Computationally, each
simple operator can first be inverted by a different processor separately. Then T n+1
can be computed by summing over all these solutions. This makes the inversion highly
efficient.
However, both of these types of operator splitting schemes require a clever choice of
splitting
K
X
A(T n ) = Ak (T n ) . (10)
k=1
An ADE Scheme for Time-Dependent Evolution Equations 3

The method for splitting might be equation-specific or might not be easy to generalize in
high dimensions.
In this paper, we propose applying a simple operator splitting method based on the
so-called Alternative Direction Explicit (ADE) scheme [7, 1]. Similar to the AOS schemes,
this proposed numerical scheme can be easily parallelized. More importantly, this ADE
scheme can not only be implemented in a way similar to an explicit method, but is also
unconditionally stable similar to an implicit method.
The paper is organized as follows. In Section 2, we first revisit the Alternative Di-
rection Explicit (ADE) scheme proposed in [7, 1], which was developed to solve the heat
equation. Then we will generalize the scheme in Section 3 to solve other evolution equa-
tions by deriving an explicit expression to split the operator A. In the same section, we
will also show the accuracy and the stability of applying the ADE scheme to a wider
range of L. In Section 4, we use some numerical examples to demonstrate the simplicity
of applying the ADE scheme to higher order and nonlinear equations in both one- and
two-dimensional spaces. Finally in Section 5, we give numerical examples to show the
improvement in the time step size.

2 The ADE Scheme for the Heat Equation


In this section, we review the previous analysis in [7, 1] applying the ADE scheme to solve
the heat equation. For simplicity, we only deal with the one-dimensional case. Similar
analysis can be applied to higher dimensional equations.
The following ADE scheme was first used to solve the heat equation

T 2T
= (11)
t x2
with the boundary conditions T (x0 ) = T0 and T (xN +1 ) = TN +1 .
Given the solution T n at t = tn , we use the following algorithm to determine T n+1 ,
defined at tn+1 , on grid point x = xi with i = 1, 2, . . . , N ,
1. Set uni = Tin and vin = Tin for i = 1, 2, . . . , N ;
2. For i = 1, 2, . . . , N , solve

un+1 uni un+1 un+1 uni + uni+1


i
= i1 i
; (12)
t x2
3. For i = N, N 1, . . . , 1, solve

vin+1 vin v n vin vin+1 + vi+1


n+1
= i1 ; (13)
t x2
4. Compute
un+1 + v n+1
Tin+1 = i
. (14)
2
Notice that according to the index-sweeping-like procedures in Step 2 and Step 3, both
un+1
i and vin+1 can be computed explicitly. When we calculate un+1 i in Step 2, because
the index is in the ascending order, we have already known the value un+1 i1 on the right
n+1
hand side of (12). Similarly, when we calculate vi in Step 3, because the index is now
n+1
in the descending order, we have already known the value vi+1 on the right hand side of
(13). As a result, the whole method is fully explicit.
Other than its explicitness, another interesting property of the ADE scheme concerns
the accuracy. In truncational analysis, although the accuracies in computing u and v
in Step 2 and Step 3 are both O[t2 , x2 , (t/x)2 ], the averaging step in Step 4 will
An ADE Scheme for Time-Dependent Evolution Equations 4

cancel out all the terms in the form of (t/x)r . Therefore, the overall scheme will have
the following leading order terms from the truncational analysis
t2 x2
Tttt Txxxx . (15)
12 12
Perhaps the most important property is that the Von Neumann stability analysis shows
that this numerical scheme is unconditionally stable for all t > 0.

3 Operator Form
In this section, we will generalize the above technique to a wider class of linear equations
in higher dimensions. Given a linear time-dependent equation,
T
= L(T ) , (16)
t
we first discretize the right hand side of the equation, which implies
T
= AT + b . (17)
t
Now, we decompose the matrix A into L + D + U , where D is the diagonal part of A, and
L and U are the strictly lower and the strictly upper triangular part of A, respectively.
Further, defining B and C by
1 1
B = L + D and C = U + D , (18)
2 2
we can express the ADE scheme as
1
T n+1 = (I tB)1 (I + tC) + (I tC)1 (I + tB) T n +
2
1
(I tB)1 + (I tC)1 b . (19)
2
The matrices (I tB) and (I tC) are all either lower triangular or upper triangular.
Thus their corresponding inverses can be found easily by using simple forward or backward
substitution. In the algorithm mentioned in Section 2, these two substitutions are simply
done by switching the indexing direction. Therefore, the computational complexity for
each time step would be the same as the standard explicit scheme, i.e. O(N ) where N is
the number of grid points in the space direction.
For the rest of this section, we will use these matrix notations to analyze the accuracy
and the stability of the ADE scheme.
Theorem 3.1. If the diagonal elements of A are all non-positive, the ADE scheme (19)
is second order accurate in time.
Proof. For simplicity, we take b = 0. Because the diagonal elements of A are all non-
positive, the matrices (I tB) and (I tC) in (19) are both nonsingular. Therefore,
we can expand these inverses and get
("
# "
#)
1 X X
n+1 m m m1 m m m1
T = I+ t (B + B C) + I + t (C + C B) Tn
2 m=1 m=1

t2 2 1 3 3
= I + t A + A + t (B + B C + C B + C ) + O(t ) T n . (20)
2 2 3 4
2 2
We complete the proof by comparing this expression with the exact solution of (17), given
by
T n+1 = exp(t A)T n
X
1
= (t A)m T n . (21)
m=0
m!
An ADE Scheme for Time-Dependent Evolution Equations 5


Here we give two proofs of the stability property of the ADE scheme.
Theorem 3.2. If A is symmetric negative definite, the ADE scheme (19) is uncondi-
tionally stable.
Proof. For simplicity, we will prove only the stability of the operator (I t B)1 (I +
t C). The stability of (I t C)1 (I +t B) can be proven similarly. And, the averaging
of these two operators will still be stable.
Defining B = I t B and C = I + t C, we have

B T + B = 2I t (B + B T ) = 2I t A . (22)

Because A is positive definite, we can define k.kA as the norm induced by the
matrix A. The induced norm of B 1 C is then given by

(B 1 Cx, AB 1 Cx) (x, C T B T AB 1 Cx)


kB 1 Ck2A = sup = sup . (23)
x6=0 (x, Ax) x6=0 (x, Ax)

Replacing C by (A B), the matrix C T B T AB 1 C can be rewritten as

C T B T AB 1 C = (I t B + t A)T B T AB 1 (I t B + t A)
= A + t A(I t B)1 A + t A(I t B)T A
+t2 A(I t B)T A(I t B)1 A
= A + t AB T (t A + B T + B)B 1 A
= A + 2t (B 1 A)T (B 1 A) . (24)

This implies
kB 1 Axk22
kB 1 Ck2A = 1 2t sup < 1, (25)
x6=0 kxk2A
for all t > 0. Thus, we have

(B 1 C) kB 1 Ck < 1 (26)

for all t > 0.


Theorem 3.3. If A is lower-triangular with all diagonal elements negative, the ADE
scheme (19) is unconditionally stable.
Proof. Let dj < 0 be the diagonal elements of the matrix A. The spectral radius of
B 1 C is then given by

1 + t dj /2
1
(B C) = max <1 (27)
j 1 t dj /2

for all t > 0. And, this implies stability.


Using the same idea, if A is upper-triangular with all diagonal elements negative, the
ADE scheme (19) is also unconditionally stable.

4 Further Applications
In this section, we generalize the ADE scheme and apply it to both higher order and
nonlinear equations. Section 4.1 deals with linear equations. A generalization to nonlinear
equations will be given in Section 4.2
An ADE Scheme for Time-Dependent Evolution Equations 6

4.1 Linear Equations


4.1.1 Heat Equation with Variable Coefficients
Applying the ADE technique to the equation
T
= [k(x)T ] (28)
t
where k(x) > 0 and using central differencing to approximate the gradient operators, we
have
k1 0 0
k3/2 k2 0 0
1 0 k5/2 k3 0


B= (29)
x2 .. .. .. .. ..
. . . . .
0 0 k(2n1)/2 kn
where ki = [k(xi1/2 ) + k(xi+1/2 )]/2 or k((xi1/2 + xi1/2 )/2), and C = B T .
Therefore, A is symmetric negative definite. Using Theorem 3.2, we can easily prove
that the resulting ADE scheme is unconditionally stable for arbitrary t > 0.

4.1.2 Linear Advection Equation


Another interesting example is the linear advection equation. Applying the forward
differencing in time and the central differencing in space, we obtain
at n
un+1 = uni (u uni1 ) , (30)
i
2x i+1
which is well-known to be unconditionally unstable for all t > 0. However, employing
the idea of the ADE scheme, we obtain an unconditionally stable scheme by slightly
modifying (30). Numerically, we only need to replace either uni+1 or uni1 in the above
scheme by un+1 using
1. Set uni = uni and uni = uni for i = 1, 2, . . . , N ;
2. For i = 1, 2, . . . , N , solve
at n
un+1
i = uni (ui+1 un+1
i1 ) ; (31)

3. For i = N, N 1, . . . , 1, solve
at n+1
un+1
i = uni (ui+1 uni1 ) ; (32)

4. Compute
un+1 + un+1
un+1
i = i
. (33)
2
We can also easily generalize this type of central scheme to a higher degree of accuracy.
For example, we can have

i1
X XN
un+1
i = uni + ai t j uj + j uj , (34)
j=1 j=i+1

where i+k = ik and the -state can be n or (n + 1), depending on the direction of
the indexing. Here we briefly analyze the resulting method. We consider only half of the
ADE scheme, in which we use un+1 j for j < i and unj for j > i. The other half can be
An ADE Scheme for Time-Dependent Evolution Equations 7


analyzed in the same way. Using the Fourier analysis, with I = 1, we can compute
the amplifying factor of the scheme which is given by
PN
1 ai t j=i+1 j exp[Ik(j i)x]
= Pi1 . (35)
1 + ai t j=1 j exp[Ik(j i)x]

Thus kk = 1, which implies stability.


Although stable, these schemes are non-dispersive. This means that oscillations could
be generated near discontinuity. Therefore, this type of central ADE scheme is not
recommended for solving hyperbolic-type equations with discontinuity in the solution.
In addition to the central differencing used above, we can also use the upwind dif-
ferencing to discretize the space derivative. Guaranteed by Theorem 3.3, the resulting
scheme is stable, and therefore convergent, for all t > 0.

4.1.3 Fourth-order Diffusion Equation


For the higher order diffusion equation
T
= Txxxx , (36)
t
the stability condition for the standard fully explicit scheme is t = O(x4 ). It is possible
to relax this condition using the fully implicit scheme or the Crank-Nicloson-type scheme.
However, for higher dimensions or problems with complicated geometry, any dimensional
splitting techniques, including the popular ADI method, may no longer be useful. The
main difficulty is that the operator in each direction cannot be solved as easily as the
Laplace operator.
Of course, one could use FFT to solve this type of equation. However, it is still
necessary to solve the system of ODEs which governs the evolution of each mode,

dTk
= k 4 Tk . (37)
dt
For higher frequency modes, these equations are stiff and, therefore, require a very small
time step t.
Applying the ADE scheme to this equation, we have

3 0 0
4 3 0 0
1 1 4 3 0

B= (38)
x4 .. .. .. .. ..
. . . . .
0 1 4 3

and C = B T . More importantly, guaranteed by Theorem 3.2, this resulting numerical


scheme is unconditionally stable for any t > 0.

4.2 Nonlinear Equations


In this section, we will mainly emphasize the following two classes of nonlinear equations.
These classes have wide applications in many fields of applied mathematics. Solving them
efficiently is then especially important.
The first type is the Hamilton-Jacobi equations. These equations are hyperbolic and,
in general, the stability condition for any explicit scheme is only O(x). Compared with
those elliptic equations as in previous sections, this condition is relatively less restrictive
and therefore the improvement in using ADE is not obvious. The second class is more
An ADE Scheme for Time-Dependent Evolution Equations 8

important. They are nonlinear diffusion equations which for example govern motions of
thin film flows or remove noise in image processing.
A general way to deal with these nonlinear equations is to express them as
T
= A(T )T + b(T ) , (39)
t
where A(T ) is now a nonlinear operator involving T . This operator and the source term
b(T ) will then be linearized by using T = T n . For example, a simple implicit scheme can
be given by
T n+1 T n
= A(T n )T n+1 + b(T n ) . (40)
t
Here, we follow a similar approach.

4.2.1 H-J Equations


These equations are widely used in Level Set Methods [11] or image segmentation. For
example
1. Level Set Equation
t + vn || = 0 . (41)
2. Reinitialization equation
t + S(0 )(|| 1) = 0 . (42)

To solve these equations using the ADE scheme, we first rewrite them as

+ H() = 0 , (43)
t
with a corresponding Hamiltonian. Traditionally, the time-derivative can be approxi-
mated using a high order TVD Runge-Kutta method [13], while the Hamiltonian can
be discretized using the Osher-Sethian scheme [11], the Lax-Friedrichs scheme (LF) [4],
the Local Lax-Friedrichs (LLF) scheme [14], the Roe-Fixed scheme [14], or the Godunov
scheme [3]. Among them all, LF, or LLF, is the easiest to implement. For a general
Hamiltonian, we have the numerical Hamiltonian
+ +
x + x x x
H() = H , (44)
2 2
where x are the forward and the backward difference approximations of the derivative
which can be obtained using a high order ENO [13, 14] or WENO [6] reconstruction, and
is the dissipation coefficient given by

H(p)

= max . (45)
p
For simplicity, we first consider the case where
x are obtained using the first order
forward and backward difference, respectively. Therefore, we have the following approxi-
mation for the H-J equation,

i i+1 i1 i+1 2i + i1
+H = 0. (46)
t 2x 2x
Now, we apply the idea of the ADE scheme. To make the operator (I tB)1 simple to
calculate, all values of inside the nonlinear Hamiltonian will be taken on t = tn . This
gives
n
t n+1 t n t i+1 ni1
1+ i = 1 i + ( + i1 ) tH , (47)
2x 2x 2x i+1 2x
An ADE Scheme for Time-Dependent Evolution Equations 9

where can either be n+1 or n depending on the direction of the indexing. This
resulting scheme is unconditionally stable for all t > 0, proven by Theorem 3.2, and
second order accurate in time and first order accurate in space.
In evaluating the Hamiltonian, we can actually implement a high order ENO or WENO
scheme for the derivative, i.e.
n +
t n+1 t n t (i )x + (ni )
x
1+ i = 1 i + ( + )tH . (48)
2x 2x 2x i+1 i1 2
However, because of the x order diffusion term, the overall accuracy in space will not
be significantly improved.
Notice that this technique can also be applied to the linear advection equation by
treating H() = u .

4.2.2 Nonlinear Diffusion Equations


Another class of nonlinear equations is the nonlinear diffusion equations. They can be
found in image processing or thin film flow modeling. We list only a few of them here.
1. The modified lubrication equation
h 4h
+ h 4 = 0 (49)
t x
for some R. One possible numerical scheme is to follow the one in Section 4.1.3
where the diffusion coefficient can be approximated by (hn ) .
One variation of the above equation is the lubrication equation, given by

h 3h
+ h 3 = 0 . (50)
t x x
More details in solving this equation will be given later in Section 5.3.
2. The equation for Total Variation (TV) denoising [12] is given by
u
= [g(|u|)u] (u u0 ) , (51)
t
with g(|u|) = 1/|u|. This equation can be solved easily using a scheme similar
to the one in Section 4.1.1. More details in solving this equation will be given later
in Section 5.4.
3. Texture/Cartoon decomposition in image processing [8]

u 1 u
= (u u0 ) . (52)
t 2 |u|
To discretize the equation, we use a similar approach as in the TV-denoising equa-
tion. Again, we can treat g(|u|) = 1/|u|, while the term in the square bracket
[] can be approximated by
x x+ y y+ 0
i,j ui1,j + i,j ui+1,j + i,j ui,j1 + i,j ui,j+2 + i,j ui,j . (53)
Next, we can apply a standard central differencing for the Laplacian, giving an
expression based on the following 13 values ui,j , ui1,j , ui2,j , ui,j1 , ui,j2 and
ui1,j1 . It is then straight forward to apply the ADE techniques.

5 Test Cases
The computations below are done in a cluster system with each node having a 3.0 GHz
hyperthreading Pentium IV processor and 2GB of memory.
An ADE Scheme for Time-Dependent Evolution Equations 10

5.1 The Fourth-order Heat Equation


We solve
Tt = Txxxx , (54)
with the initial condition T = 1 when x > 0.5 and T = 0 otherwise. The boundary
conditions are T (x = 1) = 1, T (x = 0) = 0 and Tx = 0 at both end points. Using
different numerical schemes, we compute the solution at t = 6.25 108 .
Figure 1 shows the solutions obtained using the standard fully explicit scheme with
t = 0.1x4 and using the ADE scheme with t = x4 , 2x4 and 10x4 respectively.
Notice that using the standard explicit scheme, the stability condition is given by t <
0.125x4 .
1.06 FTCP 0.1
ADE 1
ADE 2 FTCP 0.1
1.05
ADE 10 ADE 1
1 ADE 2
1.04 ADE 10

1.03 0.8

1.02

0.6
1.01

1
0.4

0.99

0.2
0.98

0.97
0

0.96

0.2
0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6
FTCS 0.1 4 |FTCSADE|
x 10
1.2 ADE 0.1 3.5

1 3

0.8 2.5

0.6 2

0.4 1.5

0.2 1

0 0.5

0.2 0
0 0.2 0.4 0.6 0.8 1 0 0.2 0.4 0.6 0.8 1

Figure 1: (Example 5.1) First row shows solutions using the standard explicit scheme with
t = 0.1x4 and the proposed ADE scheme with much larger step sizes. First figure on the
second row shows a comparison of two schemes using the same t = 0.1x4 .

We also performed a convergence test for the same equation. The initial condition we
chose is
T (x, t = 0) = cos(2x) in x [0, 1]. (55)
The exact solution can easily be computed,

Texact (x, t) = exp(16 4 t) cos(2x) . (56)


An ADE Scheme for Time-Dependent Evolution Equations 11

N \t 0.5/4004 1.0/4004 2.0/4004 4.0/4004


21 0.00214777236180 0.00214777236586 0.00214777237287 0.00214777239804
41 0.00052974323039 0.00052974332658 0.00052974371361 0.00052974526166
81 0.00013114337822 0.00013114944076 0.00013117370438 0.00013127075711
161 0.00003273907817 0.00003312413074 0.00003466433462 0.00004082485682

Table 1: (Example 5.1) L2 Errors.

N \t 0.5/4004 1.0/4004 2.0/4004 4.0/4004


21 - 1.66381009134637 1.71177376531252 -
41 - 2.00071013686408 1.99944714308720 -
81 - 2.00072867857121 1.99997111723545 -
161 - 1.99999479735959 1.99993994756767 -

Table 2: (Example 5.1) Order of convergence in the t-direction, (r1 )k,l .

Table 1 shows the L2 errors defined by


sX
Ek,l = (Ti Texact (xi , tfinal ))2 xl (57)
i

at tfinal = 1/1002 using different step sizes tk . To compute the accuracy of the method,
we assume the leading order of the error can be expressed in the form

Ek,l = 1 trk1 + 2 xrl 2 . (58)

Using the data from Table 1, we define



1 Ek,l Ek1,l 1 Ek,l Ek,l1
(r1 )k,l = log and (r2 )k,l = log . (59)
log 2 Ek+1,l Ek,l log 2 Ek,l+1 Ek,l

Their numerical values are given in Table 2 and 3. It is clear that the numerical scheme
is second order accurate in both the t- and x-directions.

5.2 A Hamilton-Jacobi Equation


We solve
t + H(x ) = 0 , (60)

N \t 0.5/4004 1.0/4004 2.0/4004 4.0/4004


21 - - - -
41 2.12099072959563 2.12101174641717 2.12109585752083 2.12143234224636
81 2.04909457955820 2.05460090325181 2.07684012570413 2.16941638856231
161 - - - -

Table 3: (Example 5.1) Order of convergence in the x-direction, (r2 )k,l .


An ADE Scheme for Time-Dependent Evolution Equations 12

with H(p) = cos(p + 1). We discretize the x-axis by 201 grid point and solve the
equation up to tfinal = 0.15. To approximate x , we use only simple forward and
backward differences.
On the left hand side of Figure 2, we show the solutions using the ADE scheme with
t = 0.01x and 15x. Because 15x = 0.15 = tfinal , the solution ADE15 is essentially
obtained by using only one time marching step. On the right hand side of the same figure,
we compare the solutions at t = tfinal using different t.

1.5 |ADE ADE | |ADE ADE |


0.01 1 0.01 3
ADE0.01 0.01 0.025
ADE15
0.008 0.02

1 0.006 0.015

0.004 0.01

0.002 0.005
0.5
0 0
1 0.5 0 0.5 1 1 0.5 0 0.5 1

|ADE0.01ADE5| |ADE0.01ADE15|
0 0.04 0.08

0.03 0.06

0.5 0.02 0.04

0.01 0.02

1 0 0
1 0.8 0.6 0.4 0.2 0 0.2 0.4 0.6 0.8 1 1 0.5 0 0.5 1 1 0.5 0 0.5 1

Figure 2: (Example 5.2) Solutions using the proposed ADE scheme with t = 0.01x2 and
15x2 at tfinal = 15x2 . Comparisons of the solutions using different step sizes are shown
on the right hand side.

5.3 The Lubrication Equation


This equation was studied extensively in [18]

h 3h
+ f (h) 3 = 0 , (61)
t x x

where f (h) = h1/2 . To regularize the equation, one can replace f (h) by

h4 f (h)
f (h) = , (62)
f (h) + h4

with = 1011 . The initial condition of this equation is given by

h(x) = 0.8 cos(x) + 0.25 cos(2x) . (63)

On both end points at x = 0 and x = 1, we impose reflective boundary conditions, i.e.


we have h0 = h00 = 0. Numerically, on the left boundary, we set h1 = h1 and h2 = h2 .
Similar boundary conditions are imposed on the other end point at x = 1. In this
numerical test, we use 501 grid points to discretize the x-direction, or x4 = 1.6 1011 ,
and t = 10x4 .
Using the proposed ADE approach, we have

0 0
1+ hn+1
i = 1 hni (+2 hi+2 + +1 hi+1 + 1 hi1 + 2 hi2 ) , (64)
2 2
An ADE Scheme for Time-Dependent Evolution Equations 13

where
t n n
= , 0 = 3(fi+1/2 + fi1/2 ),
x4
n n n
2 = fi1/2 , 1 = (fi+1/2 + 3fi1/2 ),
n n n
+1 = (3fi+1/2 + fi1/2 ) , +2 = fi+1/2 . (65)

3
2 x 10
5
t=1.25d4
1.8 t=2.50d4 t=1.25d4
t=3.75d4 4.5 t=2.50d4
t=5.00d4 t=3.75d4
1.6 t=6.25d4 t=5.00d4
t=7.50d4 4 t=6.25d4
t=8.75d4 t=7.50d4
1.4 t=1.00d3 t=8.75d4
3.5 t=1.00d3

1.2
3

1
h

2.5

h
0.8 2

0.6 1.5

0.4 1

0.2 0.5

0 0
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1 0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1
x x
4
1.8 x 10
5
t=1.00d3
t=2.00d3 t=1.00d3
1.6
t=3.00d3 4.5 t=2.00d3
t=4.00d3 t=3.00d3
t=5.00d3 t=4.00d3
1.4 t=6.00d3 4 t=5.00d3
t=7.00d3 t=6.00d3
t=8.00d3 t=7.00d3
3.5 t=8.00d3
1.2

3
1
h

2.5
h

0.8

2
0.6
1.5

0.4
1

0.2
0.5

0 0
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1 0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08
x x

Figure 3: (Example 5.3) Figures on the first row shows the solution of the lubrication equation
at t = k 1.25 104 for k = 1, . . . , 8. Second rows show the solution at a later time
t = k 104 for k = 1, . . . , 8.
Solutions are plotted in Figure 3. Although the exact solution for this problem is not
available, our solutions look reasonably close to those in [18].

5.4 TV denoising
Here we study in detail the method of applying TV regularization in image processing
[12] using the proposed ADE scheme. Given a noisy image u0 , we solve the following
equation to remove the noise,
u
= (g(ux , uy )u) (u u0 ) , (66)
t
where
1
g(ux , uy ) = q . (67)
u2x + u2y +
An ADE Scheme for Time-Dependent Evolution Equations 14

In this numerical test, we take x = y = 1, = 1010 . The test image we used is a


512-by-512 pixels image of Elaine, as shown in Figure 4. This image is taken from the
USC-SIPI Image Database [5]. To obtain a noisy version of the original clean image, we
add 20% random uniform noise, i.e.

unew
0 = uold
0 + 0.2 , (68)
where is the maximum gray level of the image, which equals 256, and is a uniform
random variable from [1, 1].

Figure 4: (Example 5.4) Original noisy image of Elaine and the one with 20% more noise.

For the standard fully explicit scheme, the stability condition is given by
q
t = O( u2x + u2y x2 ) . (69)

In practise, this condition is too restrictive in flat regions where u2x + u2y ' 0. To relax
this restriction, [9] has proposed multiplying the right hand side of equation (66) by a
factor of |u|. The paper has argued that away from the places where g() is singular,
the steady state solution from solving this new equation is the same as the one obtained
from the original equation. With this extra factor, the stability condition can be relaxed
to
t = O(x2 ) . (70)
However, in the current paper, we do not implement this idea.
Violating this stability condition, we first implement the standard explicit scheme
using t = 0.1x2 . The numerical results after 104 iterations are shown in Figure 5.
Applying the ADE approach to equation (66) directly, we have

t n+1
1 + (gx+ + gx + gy+ + gy ) + ui,j =
2 2

t n
1 (gx+ + gx + gy+ + gy ) ui,j + gx+ ui+1,j + gx ui1,j
2 2
+gy+ ui,j+1 + gy ui,j1 + t(u0 )i,j , (71)
where = x = y = t/(xy),
gx = g(Dx uni,j , Dy0 uni,j ) and gy = g(Dx0 uni,j , Dy uni,j ) . (72)
An ADE Scheme for Time-Dependent Evolution Equations 15

Figure 5: (Example 5.4) (From left to right, top to bottom) Steady state solutions using the
standard fully explicit scheme with t = 0.1x2 and = 0.005, 0.010, 0.020 and 0.050.

With this discretization, we have computed the solution using t = 0.1x2 . The
solution is shown in Figure 6. It is similar to the one we obtained previously. However,
because the ADE scheme eliminates the stability restriction, we have also implemented
the cases where t = 10x2 and 40x2 . The numerical solutions are shown in Figures
7 to 8. From the plot of the change in the TV, we see that these steady state solutions
are obtained using as few as 50 iterations.
Because we are able to use a much larger time step without violating any stability
condition, we can obtain the steady state solution in much fewer iterations. This speedup
in the computational efficiency is clearly shown in Figure 9 and 10. From these plots,
we see that for those cases with smaller step sizes, steady state solutions are obtained
using approximately 3000 iterations. For those cases with larger step sizes, the steady
state solution is reached after only around 50 iterations. However, from Figure 11, as we
further increase the step size t from 10x2 to 40x2 , there is no extensive improvement
in the speed of convergence. One possible reason is that the error from the numerical
scheme has significantly grown when we increase t.
An ADE Scheme for Time-Dependent Evolution Equations 16

Figure 6: (Example 5.4) (From left to right, top to bottom) Steady state solutions using the
proposed ADE scheme with t = 0.1x2 and = 0.005, 0.010, 0.020 and 0.050.

To compare the computational speed of using different methods, we have also calcu-
lated the total CPU time for 104 iterations using the standard explicit method and the
ADE scheme, respectively. On average, the standard explicit scheme requires 0.7851 sec-
ond/iteration, while the ADE scheme requires 0.8631 second/iteration. It seems like the
ADE scheme takes longer. However, if we look at the total computational time to reach
the steady state solution, we see that it takes approximately 45 seconds for the ADE
scheme but approximately 4000 seconds for the standard fully explicit scheme. The ADE
scheme is still overall much faster and speeds up the computations by a larger factor.
The final point we want to make is that one needs to be very cautious in using the
standard fully explicit scheme with a stability violating t. Different from the situation
in Section 5.1, the numerical solution from the explicit scheme may not blow up. We have
performed tests to see how the TV of the image varies with the step size. Figure 12 shows
the solutions using some larger t with = 0.010. The TV of the image actually decreases
for the first few iterations, goes up a little bit for the next few and finally stays relatively
flat. More importantly, the TV-norm of these steady state solutions depends on the t
An ADE Scheme for Time-Dependent Evolution Equations 17

Figure 7: (Example 5.4) (From left to right, top to bottom) Steady state solutions using the
proposed ADE scheme with t = 10x2 and = 0.005, 0.010, 0.020 and 0.050.

we have chosen. This is a subtle issue computationally in using a conditionally stable


scheme. On one hand, if we follow
q the stability condition of the standard explicit scheme,
t has to be in the order of u2x + u2y , which makes the computations impractical. On
the other hand, if we ignore this condition and use a relatively small (intuitionally) step
size, a wrong solution may unfortunately still stay stable. Therefore, it is not clear if the
steady state solutions we obtained above in Figure 5 using the standard explicit scheme
really correspond to the true steady state solutions of equation (66). In other words,
one cannot be sure how much the steady state solution is affected by the stability in the
numerical scheme.

6 Conclusion
We have successfully applied an unconditionally stable, while still explicit, scheme to non-
linear evolution equations. This resulting method has shown a significant improvement
An ADE Scheme for Time-Dependent Evolution Equations 18

Figure 8: (Example 5.4) (From left to right, top to bottom) Steady state solutions using the
proposed ADE scheme with t = 40x2 and = 0.005, 0.010, 0.020 and 0.050.

in the computational efficiency, as clearly demonstrated by different numerical examples.

Acknowledgment
S. Leung is supported by (...). He would also like to thank both J.J. Xu for valuable
discussions on the section of image processing and the UCLA Department of Mathematics
for providing the computing facilities supported by NSF SCREMS grant DMS-0112330
and the Regents of the University of California.

References
[1] H.Z. Barakat and J.A. Clark. On the solution of diffusion equation by numerical
methods. J. Heat Transfer, 88:421427, 1966.
An ADE Scheme for Time-Dependent Evolution Equations 19

6 6
x 10 x 10
15 15
=0.005 =0.005
=0.010 =0.010
=0.020 =0.020
=0.050 =0.050

10 10

5 5

0 0
0 1000 2000 3000 4000 5000 6000 7000 8000 9000 10000 0 500 1000 1500 2000 2500 3000 3500 4000 4500 5000
6 6
x 10 x 10
15 15
=0.005 =0.005
=0.010 =0.010
=0.020 =0.020
=0.050 =0.050

10 10

5 5

0 0
0 500 1000 1500 2000 2500 3000 3500 4000 4500 5000 0 500 1000 1500 2000 2500 3000 3500 4000 4500 5000

Figure 9: (Example 5.4) (From left to right, top to bottom) Change in the TV of the image
using the standard explicit scheme with t = 0.1x2 and the proposed ADE scheme with
t = 0.1x2 , 10x2 and 40x2 .

[2] D. Barash, M. Israeli, and R. Kimmel. An accurate operator splitting scheme for
nonlinear diffusion filtering. Proceedings of the Third International Conference on
Scale-Space and Morphology in Computer Vision, pages 281289, 2001.
[3] M. Bardi and S. Osher. The nonconvex multidimensional riemann problem for
hamilton-jacobi equations. SIAM J. Math. Anal., 22:344351, 1991.
[4] M. G. Crandall and P. L. Lions. Two approximations of solutions of Hamilton-Jacobi
equations. Math. Comp., 43:119, 1984.
[5] USC-SIPI Image Database. http://sipi.usc.edu/services/database/database.html.
[6] G. S. Jiang and D. Peng. Weighted ENO schemes for Hamilton-Jacobi equations.
SIAM J. Sci. Comput., 21:21262143, 2000.
[7] B.K. Larkin. Some stable explicit difference approximations to the diffusion equation.
Math. Comp., 18:196202, 1964.
[8] J. Osher, A. Sole, and L. Vese. Image decomposition and restoration using total
variation minimization and the h1 norm. SIAM J. Multi. Model. & Simul., 1(3):349
370, 2003.
[9] S. Osher and R. P. Fedkiw. Level Set Methods and Dynamic Implicit Surfaces.
Springer-Verlag, New York, 2003.
[10] S. Osher and N. Paragios (Eds.). Geometric Level Set Methods in Imaging, Vision
and Graphics. Springer, 2003.
An ADE Scheme for Time-Dependent Evolution Equations 20

6 6
x 10 x 10
15 15
=0.005 =0.005
=0.010 =0.010
=0.020 =0.020
=0.050 =0.050

10 10

5 5

0 0
0 10 20 30 40 50 60 70 80 90 100 0 10 20 30 40 50 60 70 80 90 100
6 6
x 10 x 10
15 15
=0.005 =0.005
=0.010 =0.010
=0.020 =0.020
=0.050 =0.050

10 10

5 5

0 0
0 10 20 30 40 50 60 70 80 90 100 0 10 20 30 40 50 60 70 80 90 100

Figure 10: (Example 5.4) (From left to right, top to bottom) A close-up in the change in
the TV of the image using the standard explicit scheme with t = 0.1x2 and the proposed
ADE scheme with t = 0.1x2 , 10x2 and 40x2 .

[11] S. J. Osher and J. A. Sethian. Fronts propagating with curvature dependent speed:
algorithms based on Hamilton-Jacobi formulations. J. Comput. Phys., 79:1249,
1988.
[12] L. Rudin, S.J. Osher, and E. Fatemi. Nonlinear total variation based noise removal
algorithms. Physica D, 60:259268, 1992.
[13] C. W. Shu and S. J. Osher. Efficient implementation of essentially non-oscillatory
shock capturing schemes. J. Comput. Phys., 77:439471, 1988.
[14] C.W. Shu and S. Osher. Efficient implementation of essentially non-oscillatory shock
capturing schemes 2. J. Comput. Phys., 83:3278, 1989.
[15] P. Smereka. Semi-implicit level set methods for curvature and surface diffusion
motion. J. Sci. Comput., 1-3:439456, 2003.
[16] J. C. Strikwerda. Finite difference schemes and partial differential equations.
Wadsworth-Brooks/Cole, Pacific Grove, California, 1989.
[17] J. Weickert, B.M. ter Haar Romeny, and M.A. Viergever. Efficient and reliable
schemes for nonlinear diffusion filtering. IEEE Transactions on Image Processing,
7:398410, 1998.
[18] L. Zhornitshaya and A.L. Bertozzi. Positivity-preserving numerical schemes for
lubrication-type equations. SIAM J. Num. Anal., 37:523555, 2000.
An ADE Scheme for Time-Dependent Evolution Equations 21

6 6
x 10 x 10
15 15
=0.005 =0.005
=0.010 =0.010
=0.020 =0.020
=0.050 =0.050

10 10

5 5

0 0
0 2 4 6 8 10 12 14 16 18 20 0 2 4 6 8 10 12 14 16 18 20

Figure 11: (Example 5.4) Another close-up in the change in the TV of the image using the
proposed ADE scheme with t = 10x2 and 40x2 .

6
x 10
15
Explicit t=2x2
Explicit t=3x2
Explicit t=4x2
Explicit t=5x2

10
TV

0
0 5 10 15 20 25 30 35 40

Figure 12: (Example 5.4) Changes in the TV of the image using the standard explicit scheme
with = 0.010 and t = 2x2 , 3x2 , 4x2 and 5x2 .

You might also like