<- previous    index    next ->
Some partial differential equations are difficult to solve symbolically
and some are difficult to solve numerically.
This lecture covers the numerical solution of simple partial
differential equations where the boundary values are known.
See  simple definitions  if needed.
We are told there is an unknown function z(x,y) that satisfies
the partial differential equation:
   (read 'd' as the partial derivative symbol, '^' as exponent)
  d^2z(x,y)/dx^2 + d^2z(x,y)/dy^2 = c(x,y)         
and we are given the function c(x,y)
and we are given the values of z(x,y) on the boundary
of the domain of x,y in xmin,ymin to xmax,ymax            
To compute the numerical solution of z(x,y) at a set of points
we choose the number of points in the x and y directions, nx, ny.
Thus we have a grid of cells typically programmed as a
two dimensional array.
 From the above we get a step size  hx = (xmax-xmin)/(nx-1) and
hy = (ymax-ymin)/(ny-1). For our first solution we choose
hx = hy = h and just use a step size of h.
If we need z(x,y) at some point not on our solution grid,
we can use two dimensional interpolation to find the desired value.
 
Now, write the differential equation as a second order
numerical difference equation.
(Numerical derivatives from nderiv.out order 2, points 3, term 1)
                        
d^2z(x,y)/dx^2 + d^2z(x,y)/dy^2 =                                  
 1/h^2(z(x-h,y)-2z(x,y)+z(x+h,y)) +
 1/h^2(z(x,y-h)-2z(x,y)+z(x,y+h)) +O(h^2) 
Setting the above equal to c(x,y) and collecting terms
d^2z(x,y)/dx^2 + d^2z(x,y)/dy^2 =  c(x,y) becomes
 1/h^2(z(x-h,y)+z(x+h,y)+z(x,y-h)+z(x,y+h)-4z(x,y))=c(x,y) 
                                                
now solve for a new z(x,y), based on neighboring grid points                                   
z(x,y)= (z(z-h,y)+z(x+h,0)+z(x,y-h)+z(x,y+h)-c(x,y)*h^2)/4     
The formula for z(x,y) is programmed based on indexes i and j
such that x=xmin+i*h, y=ymin+j*h  for i=1,nx-2  j=1,ny-2
Note that the boundary values are set and unchanged for the four
sides  i=0 for j=0,ny-1    i=nx-1 for j=0,ny-1
       j=0 for i=0,nx-1    j=ny-1 for i=0,nx-1
and the interior cells are set to some value, typically zero.
Then iterate, computing new interior cells based on the previous
set of cells including the boundary.
Compute the absolute value of the difference between each new
interior cell and the previous interior cell. A stable problem
will result in this value getting monotonically smaller.
The stopping condition may be based on the above difference
value or on the number of iterations.
To demonstrate the above development, a known z(x,y) is used.
The boundary values are set and the iterations computed.
Since the solution is known, the error can be computed at
each cell and reported for each iteration.
At several iterations, the computed solution and the errors
from the known exact solution are printed.
The same code has been programmed in "C", Java, Fortran 95, Ada 95 and
Matlab as shown below with file types .c, .java, .f90, .adb and .m:
"C" source code  pde3.c
output of pde3.c
Fortran 95 source code  pde3.f90
output of pde3.f90
Java source code  pde3.java
output of pde3.java
Ada 95 source code  pde3.adb
output of pde3.adb
Matlab 7 source code  pde3.m
output of pde3.m
You may tailor any of the above code to solve second order
partial differential equations in two independent variables.
1) You need a function  c(x,y)  that is the forcing function, the right
hand side of the differential equation.
2) You need a function  z(x,y)  that provides at least the boundary
conditions. If your  z(x,y)  is not a test solution, remove the "check"
code.
3) If your differential equation is different, then use  nderiv.out
to find the coefficients and create the function  z00(i,j) that
computes the next value of a solution point from the surrounding
previous solution points. 
The following examples will be covered for a more general case
in the next lecture. The same problem is solved as given above,
using a method of solving simultaneous linear equations, rather
than an iterative method. The files corresponding to the above
examples are with minimum modifications are:
"C" source code  pde3_eq.c
output of pde3_eq.c
Matlab 7 source code  pde3_eq.m
output of pde3_eq.m
The instructor understands that some students have a strong
prejudice in favor of, or against, some programming languages.
After about 50 years of programming in about 50 programming
languages, the instructor finds that the difference between
programming languages is mostly syntactic sugar. Yet, since
students may be able to read some programming languages
easier than others, these examples are presented in "C",
Fortran 90, Java, Ada and Matlab. The intent was to do a quick
translation, keeping most of the source code the same,
for the different languages. Style was not a consideration.
Some rearranging of the order was used when convenient.
In Java and Ada the quick and dirty formatting was used
and thus it is suggested to look at the formatted output of
"C" or Fortran. The numerical results are almost exactly
the same although the presentation differs considerably.
The Matlab code is a combination of "C" and Fortran given
as a single file with internal functions. The subscript base
is shifted from 0 to 1 as in old Fortran.
From the above we get a step size  hx = (xmax-xmin)/(nx-1) and
hy = (ymax-ymin)/(ny-1). For our first solution we choose
hx = hy = h and just use a step size of h.
If we need z(x,y) at some point not on our solution grid,
we can use two dimensional interpolation to find the desired value.
 
Now, write the differential equation as a second order
numerical difference equation.
(Numerical derivatives from nderiv.out order 2, points 3, term 1)
                        
d^2z(x,y)/dx^2 + d^2z(x,y)/dy^2 =                                  
 1/h^2(z(x-h,y)-2z(x,y)+z(x+h,y)) +
 1/h^2(z(x,y-h)-2z(x,y)+z(x,y+h)) +O(h^2) 
Setting the above equal to c(x,y) and collecting terms
d^2z(x,y)/dx^2 + d^2z(x,y)/dy^2 =  c(x,y) becomes
 1/h^2(z(x-h,y)+z(x+h,y)+z(x,y-h)+z(x,y+h)-4z(x,y))=c(x,y) 
                                                
now solve for a new z(x,y), based on neighboring grid points                                   
z(x,y)= (z(z-h,y)+z(x+h,0)+z(x,y-h)+z(x,y+h)-c(x,y)*h^2)/4     
The formula for z(x,y) is programmed based on indexes i and j
such that x=xmin+i*h, y=ymin+j*h  for i=1,nx-2  j=1,ny-2
Note that the boundary values are set and unchanged for the four
sides  i=0 for j=0,ny-1    i=nx-1 for j=0,ny-1
       j=0 for i=0,nx-1    j=ny-1 for i=0,nx-1
and the interior cells are set to some value, typically zero.
Then iterate, computing new interior cells based on the previous
set of cells including the boundary.
Compute the absolute value of the difference between each new
interior cell and the previous interior cell. A stable problem
will result in this value getting monotonically smaller.
The stopping condition may be based on the above difference
value or on the number of iterations.
To demonstrate the above development, a known z(x,y) is used.
The boundary values are set and the iterations computed.
Since the solution is known, the error can be computed at
each cell and reported for each iteration.
At several iterations, the computed solution and the errors
from the known exact solution are printed.
The same code has been programmed in "C", Java, Fortran 95, Ada 95 and
Matlab as shown below with file types .c, .java, .f90, .adb and .m:
"C" source code  pde3.c
output of pde3.c
Fortran 95 source code  pde3.f90
output of pde3.f90
Java source code  pde3.java
output of pde3.java
Ada 95 source code  pde3.adb
output of pde3.adb
Matlab 7 source code  pde3.m
output of pde3.m
You may tailor any of the above code to solve second order
partial differential equations in two independent variables.
1) You need a function  c(x,y)  that is the forcing function, the right
hand side of the differential equation.
2) You need a function  z(x,y)  that provides at least the boundary
conditions. If your  z(x,y)  is not a test solution, remove the "check"
code.
3) If your differential equation is different, then use  nderiv.out
to find the coefficients and create the function  z00(i,j) that
computes the next value of a solution point from the surrounding
previous solution points. 
The following examples will be covered for a more general case
in the next lecture. The same problem is solved as given above,
using a method of solving simultaneous linear equations, rather
than an iterative method. The files corresponding to the above
examples are with minimum modifications are:
"C" source code  pde3_eq.c
output of pde3_eq.c
Matlab 7 source code  pde3_eq.m
output of pde3_eq.m
The instructor understands that some students have a strong
prejudice in favor of, or against, some programming languages.
After about 50 years of programming in about 50 programming
languages, the instructor finds that the difference between
programming languages is mostly syntactic sugar. Yet, since
students may be able to read some programming languages
easier than others, these examples are presented in "C",
Fortran 90, Java, Ada and Matlab. The intent was to do a quick
translation, keeping most of the source code the same,
for the different languages. Style was not a consideration.
Some rearranging of the order was used when convenient.
In Java and Ada the quick and dirty formatting was used
and thus it is suggested to look at the formatted output of
"C" or Fortran. The numerical results are almost exactly
the same although the presentation differs considerably.
The Matlab code is a combination of "C" and Fortran given
as a single file with internal functions. The subscript base
is shifted from 0 to 1 as in old Fortran.
    <- previous    index    next ->