| 1251 |
slepc |
1 |
/*
|
|
|
2 |
User interface for the SLEPC singular value solvers.
|
| 1376 |
slepc |
3 |
|
|
|
4 |
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
5 |
SLEPc - Scalable Library for Eigenvalue Problem Computations
|
|
|
6 |
Copyright (c) 2002-2007, Universidad Politecnica de Valencia, Spain
|
|
|
7 |
|
|
|
8 |
This file is part of SLEPc. See the README file for conditions of use
|
|
|
9 |
and additional information.
|
|
|
10 |
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
| 1251 |
slepc |
11 |
*/
|
| 1376 |
slepc |
12 |
|
| 1251 |
slepc |
13 |
#if !defined(__SLEPCSVD_H)
|
|
|
14 |
#define __SLEPCSVD_H
|
|
|
15 |
#include "slepc.h"
|
| 1253 |
slepc |
16 |
#include "slepceps.h"
|
| 1251 |
slepc |
17 |
PETSC_EXTERN_CXX_BEGIN
|
|
|
18 |
|
|
|
19 |
extern PetscCookie SVD_COOKIE;
|
|
|
20 |
|
|
|
21 |
/*S
|
|
|
22 |
SVD - Abstract SLEPc object that manages all the singular value
|
|
|
23 |
problem solvers.
|
|
|
24 |
|
|
|
25 |
Level: beginner
|
|
|
26 |
|
|
|
27 |
.seealso: SVDCreate()
|
|
|
28 |
S*/
|
|
|
29 |
typedef struct _p_SVD* SVD;
|
|
|
30 |
|
| 1364 |
slepc |
31 |
/*E
|
|
|
32 |
SVDType - String with the name of a SLEPc singular value solver
|
|
|
33 |
|
|
|
34 |
Level: beginner
|
|
|
35 |
|
|
|
36 |
.seealso: SVDSetType(), SVD
|
|
|
37 |
E*/
|
| 1251 |
slepc |
38 |
#define SVDType const char*
|
| 1324 |
slepc |
39 |
#define SVDCROSS "cross"
|
|
|
40 |
#define SVDCYCLIC "cyclic"
|
| 1251 |
slepc |
41 |
#define SVDLAPACK "lapack"
|
| 1268 |
slepc |
42 |
#define SVDLANCZOS "lanczos"
|
| 1298 |
slepc |
43 |
#define SVDTRLANCZOS "trlanczos"
|
| 1251 |
slepc |
44 |
|
| 1364 |
slepc |
45 |
/*E
|
|
|
46 |
SVDTransposeMode - determines how to handle the transpose of the matrix
|
|
|
47 |
|
|
|
48 |
Level: advanced
|
|
|
49 |
|
|
|
50 |
.seealso: SVDSetTransposeMode(), SVDGetTransposeMode()
|
|
|
51 |
E*/
|
| 1283 |
slepc |
52 |
typedef enum { SVD_TRANSPOSE_EXPLICIT, SVD_TRANSPOSE_IMPLICIT } SVDTransposeMode;
|
| 1255 |
slepc |
53 |
|
| 1364 |
slepc |
54 |
/*E
|
|
|
55 |
SVDWhich - determines whether largest or smallest singular triplets
|
|
|
56 |
are to be computed
|
|
|
57 |
|
|
|
58 |
Level: intermediate
|
|
|
59 |
|
|
|
60 |
.seealso: SVDSetWhichSingularTriplets(), SVDGetWhichSingularTriplets()
|
|
|
61 |
E*/
|
| 1272 |
slepc |
62 |
typedef enum { SVD_LARGEST, SVD_SMALLEST } SVDWhich;
|
|
|
63 |
|
| 1364 |
slepc |
64 |
/*E
|
|
|
65 |
SVDConvergedReason - reason a singular value solver was said to
|
|
|
66 |
have converged or diverged
|
|
|
67 |
|
|
|
68 |
Level: beginner
|
|
|
69 |
|
|
|
70 |
.seealso: SVDSolve(), SVDGetConvergedReason(), SVDSetTolerances()
|
|
|
71 |
E*/
|
| 1283 |
slepc |
72 |
typedef enum {/* converged */
|
|
|
73 |
SVD_CONVERGED_TOL = 2,
|
|
|
74 |
/* diverged */
|
|
|
75 |
SVD_DIVERGED_ITS = -3,
|
|
|
76 |
SVD_DIVERGED_BREAKDOWN = -4,
|
|
|
77 |
SVD_CONVERGED_ITERATING = 0 } SVDConvergedReason;
|
|
|
78 |
|
| 1251 |
slepc |
79 |
EXTERN PetscErrorCode SVDCreate(MPI_Comm,SVD*);
|
| 1345 |
slepc |
80 |
EXTERN PetscErrorCode SVDSetIP(SVD,IP);
|
|
|
81 |
EXTERN PetscErrorCode SVDGetIP(SVD,IP*);
|
| 1251 |
slepc |
82 |
EXTERN PetscErrorCode SVDSetType(SVD,SVDType);
|
|
|
83 |
EXTERN PetscErrorCode SVDGetType(SVD,SVDType*);
|
|
|
84 |
EXTERN PetscErrorCode SVDSetOperator(SVD,Mat);
|
| 1268 |
slepc |
85 |
EXTERN PetscErrorCode SVDGetOperator(SVD,Mat*);
|
| 1272 |
slepc |
86 |
EXTERN PetscErrorCode SVDSetInitialVector(SVD,Vec);
|
|
|
87 |
EXTERN PetscErrorCode SVDGetInitialVector(SVD,Vec*);
|
| 1268 |
slepc |
88 |
EXTERN PetscErrorCode SVDSetTransposeMode(SVD,SVDTransposeMode);
|
|
|
89 |
EXTERN PetscErrorCode SVDGetTransposeMode(SVD,SVDTransposeMode*);
|
| 1272 |
slepc |
90 |
EXTERN PetscErrorCode SVDSetDimensions(SVD,int,int);
|
|
|
91 |
EXTERN PetscErrorCode SVDGetDimensions(SVD,int*,int*);
|
|
|
92 |
EXTERN PetscErrorCode SVDSetTolerances(SVD,PetscReal,int);
|
|
|
93 |
EXTERN PetscErrorCode SVDGetTolerances(SVD,PetscReal*,int*);
|
|
|
94 |
EXTERN PetscErrorCode SVDSetWhichSingularTriplets(SVD,SVDWhich);
|
|
|
95 |
EXTERN PetscErrorCode SVDGetWhichSingularTriplets(SVD,SVDWhich*);
|
| 1251 |
slepc |
96 |
EXTERN PetscErrorCode SVDSetFromOptions(SVD);
|
| 1309 |
slepc |
97 |
EXTERN PetscErrorCode SVDSetOptionsPrefix(SVD,const char*);
|
|
|
98 |
EXTERN PetscErrorCode SVDAppendOptionsPrefix(SVD,const char*);
|
|
|
99 |
EXTERN PetscErrorCode SVDGetOptionsPrefix(SVD,const char*[]);
|
| 1251 |
slepc |
100 |
EXTERN PetscErrorCode SVDSetUp(SVD);
|
|
|
101 |
EXTERN PetscErrorCode SVDSolve(SVD);
|
| 1283 |
slepc |
102 |
EXTERN PetscErrorCode SVDGetIterationNumber(SVD,int*);
|
| 1337 |
slepc |
103 |
EXTERN PetscErrorCode SVDGetConvergedReason(SVD,SVDConvergedReason*);
|
| 1251 |
slepc |
104 |
EXTERN PetscErrorCode SVDGetConverged(SVD,int*);
|
|
|
105 |
EXTERN PetscErrorCode SVDGetSingularTriplet(SVD,int,PetscReal*,Vec,Vec);
|
| 1257 |
slepc |
106 |
EXTERN PetscErrorCode SVDComputeResidualNorms(SVD,int,PetscReal*,PetscReal*);
|
| 1317 |
slepc |
107 |
EXTERN PetscErrorCode SVDComputeRelativeError(SVD,int,PetscReal*);
|
| 1305 |
slepc |
108 |
EXTERN PetscErrorCode SVDGetOperationCounters(SVD,int*,int*);
|
| 1251 |
slepc |
109 |
EXTERN PetscErrorCode SVDView(SVD,PetscViewer);
|
|
|
110 |
EXTERN PetscErrorCode SVDDestroy(SVD);
|
|
|
111 |
EXTERN PetscErrorCode SVDInitializePackage(char*);
|
|
|
112 |
|
| 1331 |
slepc |
113 |
EXTERN PetscErrorCode SVDMonitorSet(SVD,PetscErrorCode (*)(SVD,int,int,PetscReal*,PetscReal*,int,void*),
|
| 1288 |
slepc |
114 |
void*,PetscErrorCode (*monitordestroy)(void*));
|
| 1331 |
slepc |
115 |
EXTERN PetscErrorCode SVDMonitorCancel(SVD);
|
| 1288 |
slepc |
116 |
EXTERN PetscErrorCode SVDGetMonitorContext(SVD,void **);
|
| 1331 |
slepc |
117 |
EXTERN PetscErrorCode SVDMonitorDefault(SVD,int,int,PetscReal*,PetscReal*,int,void*);
|
|
|
118 |
EXTERN PetscErrorCode SVDMonitorLG(SVD,int,int,PetscReal*,PetscReal*,int,void*);
|
| 1288 |
slepc |
119 |
|
| 1298 |
slepc |
120 |
EXTERN PetscErrorCode SVDDense(int,int,PetscScalar*,PetscReal*,PetscScalar*,PetscScalar*);
|
|
|
121 |
|
| 1324 |
slepc |
122 |
EXTERN PetscErrorCode SVDCrossSetEPS(SVD,EPS);
|
|
|
123 |
EXTERN PetscErrorCode SVDCrossGetEPS(SVD,EPS*);
|
|
|
124 |
|
|
|
125 |
EXTERN PetscErrorCode SVDCyclicSetExplicitMatrix(SVD,PetscTruth);
|
|
|
126 |
EXTERN PetscErrorCode SVDCyclicGetExplicitMatrix(SVD,PetscTruth*);
|
|
|
127 |
EXTERN PetscErrorCode SVDCyclicSetEPS(SVD,EPS);
|
|
|
128 |
EXTERN PetscErrorCode SVDCyclicGetEPS(SVD,EPS*);
|
|
|
129 |
|
| 1359 |
slepc |
130 |
EXTERN PetscErrorCode SVDLanczosSetOneSide(SVD,PetscTruth);
|
| 1298 |
slepc |
131 |
|
| 1359 |
slepc |
132 |
EXTERN PetscErrorCode SVDTRLanczosSetOneSide(SVD,PetscTruth);
|
| 1298 |
slepc |
133 |
|
| 1337 |
slepc |
134 |
EXTERN PetscErrorCode SVDDense(int,int,PetscScalar*,PetscReal*,PetscScalar*,PetscScalar*);
|
|
|
135 |
|
| 1251 |
slepc |
136 |
#endif
|