Exercise 1: Standard Symmetric Eigenvalue Problem#
This example solves a standard symmetric eigenproblem \(Ax= \lambda x\), where A is the matrix resulting from the discretization of the Laplacian operator in 1 dimension by centered finite differences.
Compiling#
Copy the file ex1.c to the working directory and add these lines to the makefile
ex1: ex1.o
-${CLINKER} -o ex1 ex1.o ${SLEPC_EPS_LIB}
${RM} ex1.o
Build the executable with the command
$ make ex1
Note
Example ex1 is also available in Fortran ex1f.F90.
Running the Program#
In order to run the program for a problem of order 50, type the following
$ ./ex1 -n 50
You should get an output similar to this
1-D Laplacian Eigenproblem, n=50
Number of iterations of the method: 8
Solution method: krylovschur
Number of requested eigenvalues: 1
Stopping condition: tol=1e-08, maxit=100
Number of converged eigenpairs: 3
k ||Ax-kx||/||kx||
----------------- ------------------
3.996207 4.30363e-10
3.984841 2.08631e-09
3.965946 9.98404e-09
Source Code Details#
Examine the source code of the sample program and locate the function calls mentioned in the following comments.
The Options Database: All the PETSc functionality related to the options database is available in SLEPc. This allows the user to input control data at run time very easily. In this example, the function PetscOptionsGetInt is used to check whether the user has provided a command-line option to set the value of n
, the problem dimension. If so, the variable n
is set accordingly; otherwise, n
remains unchanged.
Vectors and Matrices: Usage of matrices and vectors in SLEPc is exactly the same as in PETSc. The user can create a new parallel or sequential matrix, A
, with subroutine MatCreate, where the matrix format can be specified at runtime. The example creates a matrix, sets the nonzero values with MatSetValues and then assembles it.
Solving the Eigenvalue Problem: Usage of eigensolvers is very similar to other kinds of solvers provided by PETSc. After creating the matrix, the problem is solved by means of an EPS
object (Eigenvalue Problem Solver) via the following sequence of function calls:
EPSSetOperators
(EPS
eps
,MatA
,MatB
);EPSSetProblemType
(EPS
eps
,EPSProblemType
type
);EPSSetFromOptions
(EPS
eps
);EPSGetConverged
(EPS
eps
, PetscInt*nconv
);EPSGetEigenpair
(EPS
eps
,PetscInti
,PetscScalar*kr
,PetscScalar*ki
,Vecxr
,Vecxi
);EPSDestroy
(EPS
eps
)`
First, the eigenproblem solver (EPS
) context is created and the operator(s) associated with the eigensystem are set, as well as the problem type. Then various options are set for customized solution. After that, the program solves the problem, retrieves the solution, and finally destroys the EPS
context.
The above function calls are very important and will be present in most SLEPc programs. In the example source code ex1.c you will find other functions apart from these. What do they do?
Playing with EPS Options#
Now we are going to experiment with different options of the EPS
object. A full list of command-line options can be obtained by running the example with the option -help
.
To show information about the solver object:
$ ./ex1 -eps_view
Note
This option internally calls the function EPSView
. Alternatively, we could include a direct call to this function in the source code. Almost all command-line options have a related function call.
Note
All the command-line options related to the EPS
object have the -eps_
prefix.
This time, your output will include something like this
EPS Object: 1 MPI processes
type: krylovschur
50% of basis vectors kept after restart
using the locking variant
problem type: symmetric eigenvalue problem
selected portion of the spectrum: largest eigenvalues in magnitude
number of eigenvalues (nev): 1
number of column vectors (ncv): 16
maximum dimension of projected problem (mpd): 16
maximum number of iterations: 100
tolerance: 1e-08
convergence test: relative to the eigenvalue
BV Object: 1 MPI processes
type: svec
17 columns of global length 30
vector orthogonalization method: classical Gram-Schmidt
orthogonalization refinement: if needed (eta: 0.7071)
block orthogonalization method: GS
doing matmult as a single matrix-matrix product
DS Object: 1 MPI processes
type: hep
solving the problem with: Implicit QR method (_steqr)
ST Object: 1 MPI processes
type: shift
shift: 0
number of matrices: 1
This option is very useful to see which solver and options the program is using.
Try solving a much larger problem, for instance with n=400
. Note that in that case the program does not return a solution. This means that the solver has reached the maximum number of allowed iterations and the convergence criterion was not satisfied. What we can do is either increase the number of iterations
$ ./ex1 -n 400 -eps_max_it 400
or relax the convergence criterion:
$ ./ex1 -n 400 -eps_tol 1e-3
Note that in the latter case the relative error displayed by the program is significantly larger, meaning that the solution has only 3 correct decimal digits, as expected.
It is possible to change the number of requested eigenvalues. Try the following execution
$ ./ex1 -n 400 -eps_nev 3 -eps_tol 1e-7
In this case, the program did not succeed to compute two of the requested eigenpairs. This is again due to the convergence criterion, which is satisfied by some eigenpairs but not for all. As in the previous case, we could further increase the number of iterations or relax the convergence criterion. Another alternative is to increase the number of column vectors (i.e., the dimension of the subspace with which the eigensolver works). This usually improves the convergence behavior at the expense of larger memory requirements.
$ ./ex1 -n 400 -eps_nev 3 -eps_ncv 24
Note that the default value of ncv
depends on the value of nev
.
Try to set some of the above options directly in the source code by calling the related functions EPSSetTolerances
and EPSSetDimensions
. Modify and recompile the program. Use -eps_view
to check that the values are correctly set. Is it now possible to change these options from the command-line? Does this change whether you place the calls before or after the call to EPSSetFromOptions
?
Convergence is usually bad when eigenvalues are close to each other, which is the case in this example. In order to see what is happening while the eigensolver iterates, we can use a monitor to display information associated to the convergence of eigenpairs at each iteration:
$ ./ex1 -eps_monitor
or
$ ./ex1 -eps_monitor_all
Also, in some SLEPc installations, it is possible to monitor convergence graphically with the draw
viewer with draw_lg
format. For example, try this:
$ ./ex1 -n 700 -eps_nev 5 -eps_ncv 35 -eps_monitor_all draw::draw_lg -draw_pause .1
Note
The plot is drawn in an X11 pop-up window, so this requires that the display is set up correctly.
Changing the Eigensolver#
The convergence behavior for a particular problem also depends on the properties of the eigensolver being used. SLEPc provides several eigensolvers that can be selected in the source code with the function EPSSetType
, or at run time:
$ ./ex1 -eps_nev 4 -eps_type lobpcg
The following table shows some of the solvers available in SLEPc.
Solver |
Command-line Name |
Parameter |
---|---|---|
Krylov-Schur |
krylovschur |
EPSKRYLOVSCHUR |
Generalized Davidson |
gd |
EPSGD |
Jacobi-Davidson |
jd |
EPSJD |
Rayleigh-quotient conjugate gradient |
rqcg |
EPSRQCG |
Locally optimal block preconditioned CG |
lobpcg |
EPSLOBPCG |
Contour integral spectrum slice |
ciss |
EPSCISS |
Subspace Iteration |
subspace |
EPSSUBSPACE |
Power / RQI |
power |
EPSPOWER |
LAPACK |
lapack |
EPSLAPACK |
ARPACK |
arpack |
EPSARPACK |
Note
The LAPACK solver is not really a full-featured eigensolver but simply an interface to some LAPACK routines. These routines operate sequentially in dense mode and therefore are suitable only for small size problems. This solver should be used only for debugging purposes.
Note
The last one (ARPACK) may or may not be available on your system, depending on whether it was enabled during installation of SLEPc. It consists in an interface to the external ARPACK library. Interfaces to other external libraries may be available as well. These can be used as any other SLEPc native eigensolver.
Note
The default solver is krylovschur
for both symmetric and non-symmetric problems.