Actual source code: matregis.c
1: #define PETSCMAT_DLL
3: #include petscmat.h
6: EXTERN PetscErrorCode MatCreate_MAIJ(Mat);
7: EXTERN PetscErrorCode MatCreate_IS(Mat);
8: EXTERN PetscErrorCode MatCreate_MPIRowbs(Mat);
10: EXTERN PetscErrorCode MatCreate_AIJ(Mat);
11: EXTERN PetscErrorCode MatCreate_SeqAIJ(Mat);
12: EXTERN PetscErrorCode MatCreate_MPIAIJ(Mat);
14: EXTERN PetscErrorCode MatCreate_BAIJ(Mat);
15: EXTERN PetscErrorCode MatCreate_SeqBAIJ(Mat);
16: EXTERN PetscErrorCode MatCreate_MPIBAIJ(Mat);
18: EXTERN PetscErrorCode MatCreate_SBAIJ(Mat);
19: EXTERN PetscErrorCode MatCreate_SeqSBAIJ(Mat);
20: EXTERN PetscErrorCode MatCreate_MPISBAIJ(Mat);
22: EXTERN PetscErrorCode MatCreate_BDiag(Mat);
23: EXTERN PetscErrorCode MatCreate_SeqBDiag(Mat);
24: EXTERN PetscErrorCode MatCreate_MPIBDiag(Mat);
26: EXTERN PetscErrorCode MatCreate_Dense(Mat);
27: EXTERN PetscErrorCode MatCreate_SeqDense(Mat);
28: EXTERN PetscErrorCode MatCreate_MPIDense(Mat);
30: EXTERN PetscErrorCode MatCreate_MPIAdj(Mat);
31: EXTERN PetscErrorCode MatCreate_Shell(Mat);
33: EXTERN PetscErrorCode MatCreate_CSRPERM(Mat);
34: EXTERN PetscErrorCode MatCreate_SeqCSRPERM(Mat);
35: EXTERN PetscErrorCode MatCreate_MPICSRPERM(Mat);
37: EXTERN PetscErrorCode MatCreate_CRL(Mat);
38: EXTERN PetscErrorCode MatCreate_SeqCRL(Mat);
39: EXTERN PetscErrorCode MatCreate_MPICRL(Mat);
41: EXTERN PetscErrorCode MatCreate_Scatter(Mat);
42: #if defined(PETSC_HAVE_SPOOLES)
43: EXTERN PetscErrorCode MatCreate_AIJSpooles(Mat);
44: EXTERN PetscErrorCode MatCreate_SeqAIJSpooles(Mat);
45: EXTERN PetscErrorCode MatCreate_MPIAIJSpooles(Mat);
47: EXTERN PetscErrorCode MatCreate_SBAIJSpooles(Mat);
48: EXTERN PetscErrorCode MatCreate_SeqSBAIJSpooles(Mat);
49: EXTERN PetscErrorCode MatCreate_MPISBAIJSpooles(Mat);
50: #endif
51: #if defined(PETSC_HAVE_SUPERLU)
52: EXTERN PetscErrorCode MatCreate_SuperLU(Mat);
53: #endif
54: #if defined(PETSC_HAVE_SUPERLU_DIST)
55: EXTERN PetscErrorCode MatCreate_SuperLU_DIST(Mat);
56: #endif
57: #if defined(PETSC_HAVE_UMFPACK)
58: EXTERN PetscErrorCode MatCreate_UMFPACK(Mat);
59: #endif
60: #if defined(PETSC_HAVE_ESSL) && !defined(PETSC_USE_COMPLEX) && !defined(PETSC_USE_SINGLE) && !defined(PETSC_USE_MAT_SINGLE)
61: EXTERN PetscErrorCode MatCreate_Essl(Mat);
62: #endif
63: #if defined(PETSC_HAVE_LUSOL)
64: EXTERN PetscErrorCode MatCreate_LUSOL(Mat);
65: #endif
66: #if defined(PETSC_HAVE_MUMPS)
67: EXTERN PetscErrorCode MatCreate_AIJMUMPS(Mat);
68: EXTERN PetscErrorCode MatCreate_SBAIJMUMPS(Mat);
69: #endif
70: #if defined(PETSC_HAVE_DSCPACK)
71: EXTERN PetscErrorCode MatCreate_DSCPACK(Mat);
72: #endif
73: #if defined(PETSC_HAVE_MATLAB)
74: EXTERN PetscErrorCode MatCreate_Matlab(Mat);
75: #endif
76: #if defined(PETSC_HAVE_PLAPACK)
77: EXTERN PetscErrorCode MatCreate_Plapack(Mat);
78: #endif
80:
81: /*
82: This is used by MatSetType() to make sure that at least one
83: MatRegisterAll() is called. In general, if there is more than one
84: DLL, then MatRegisterAll() may be called several times.
85: */
86: EXTERN PetscTruth MatRegisterAllCalled;
90: /*@C
91: MatRegisterAll - Registers all of the matrix types in PETSc
93: Not Collective
95: Level: advanced
97: .keywords: KSP, register, all
99: .seealso: MatRegisterDestroy()
100: @*/
101: PetscErrorCode MatRegisterAll(const char path[])
102: {
106: MatRegisterAllCalled = PETSC_TRUE;
108: MatRegisterDynamic(MATMPIMAIJ, path,"MatCreate_MAIJ", MatCreate_MAIJ);
109: MatRegisterDynamic(MATSEQMAIJ, path,"MatCreate_MAIJ", MatCreate_MAIJ);
110: MatRegisterDynamic(MATMAIJ, path,"MatCreate_MAIJ", MatCreate_MAIJ);
112: MatRegisterDynamic(MATIS, path,"MatCreate_IS", MatCreate_IS);
113: MatRegisterDynamic(MATSHELL, path,"MatCreate_Shell", MatCreate_Shell);
114: #if defined(PETSC_HAVE_BLOCKSOLVE95)
115: MatRegisterDynamic(MATMPIROWBS, path,"MatCreate_MPIRowbs",MatCreate_MPIRowbs);
116: #endif
117: MatRegisterDynamic(MATAIJ, path,"MatCreate_AIJ", MatCreate_AIJ);
118: MatRegisterDynamic(MATMPIAIJ, path,"MatCreate_MPIAIJ", MatCreate_MPIAIJ);
119: MatRegisterDynamic(MATSEQAIJ, path,"MatCreate_SeqAIJ", MatCreate_SeqAIJ);
121: MatRegisterDynamic(MATCSRPERM, path,"MatCreate_CSRPERM", MatCreate_CSRPERM);
122: MatRegisterDynamic(MATMPICSRPERM, path,"MatCreate_MPICSRPERM", MatCreate_MPICSRPERM);
123: MatRegisterDynamic(MATSEQCSRPERM, path,"MatCreate_SeqCSRPERM", MatCreate_SeqCSRPERM);
125: MatRegisterDynamic(MATCRL, path,"MatCreate_CRL", MatCreate_CRL);
126: MatRegisterDynamic(MATSEQCRL, path,"MatCreate_SeqCRL", MatCreate_SeqCRL);
127: MatRegisterDynamic(MATMPICRL, path,"MatCreate_MPICRL", MatCreate_MPICRL);
129: MatRegisterDynamic(MATBAIJ, path,"MatCreate_BAIJ", MatCreate_BAIJ);
130: MatRegisterDynamic(MATMPIBAIJ, path,"MatCreate_MPIBAIJ", MatCreate_MPIBAIJ);
131: MatRegisterDynamic(MATSEQBAIJ, path,"MatCreate_SeqBAIJ", MatCreate_SeqBAIJ);
133: MatRegisterDynamic(MATSBAIJ, path,"MatCreate_SBAIJ", MatCreate_SBAIJ);
134: MatRegisterDynamic(MATMPISBAIJ, path,"MatCreate_MPISBAIJ", MatCreate_MPISBAIJ);
135: MatRegisterDynamic(MATSEQSBAIJ, path,"MatCreate_SeqSBAIJ", MatCreate_SeqSBAIJ);
137: MatRegisterDynamic(MATBDIAG, path,"MatCreate_BDiag", MatCreate_BDiag);
138: MatRegisterDynamic(MATMPIBDIAG, path,"MatCreate_MPIBDiag", MatCreate_MPIBDiag);
139: MatRegisterDynamic(MATSEQBDIAG, path,"MatCreate_SeqBDiag", MatCreate_SeqBDiag);
141: MatRegisterDynamic(MATDENSE, path,"MatCreate_Dense", MatCreate_Dense);
142: MatRegisterDynamic(MATMPIDENSE, path,"MatCreate_MPIDense", MatCreate_MPIDense);
143: MatRegisterDynamic(MATSEQDENSE, path,"MatCreate_SeqDense", MatCreate_SeqDense);
145: MatRegisterDynamic(MATMPIADJ, path,"MatCreate_MPIAdj", MatCreate_MPIAdj);
146: MatRegisterDynamic(MATSCATTER, path,"MatCreate_Scatter", MatCreate_Scatter);
147: #if defined(PETSC_HAVE_SPOOLES)
148: MatRegisterDynamic(MATAIJSPOOLES, path,"MatCreate_AIJSpooles", MatCreate_AIJSpooles);
149: MatRegisterDynamic(MATSEQAIJSPOOLES, path,"MatCreate_SeqAIJSpooles", MatCreate_SeqAIJSpooles);
150: MatRegisterDynamic(MATMPIAIJSPOOLES, path,"MatCreate_MPIAIJSpooles", MatCreate_MPIAIJSpooles);
152: MatRegisterDynamic(MATSBAIJSPOOLES, path,"MatCreate_SBAIJSpooles", MatCreate_SBAIJSpooles);
153: MatRegisterDynamic(MATMPISBAIJSPOOLES,path,"MatCreate_MPISBAIJSpooles",MatCreate_MPISBAIJSpooles);
154: MatRegisterDynamic(MATSEQSBAIJSPOOLES,path,"MatCreate_SeqSBAIJSpooles",MatCreate_SeqSBAIJSpooles);
155: #endif
156: #if defined(PETSC_HAVE_SUPERLU)
157: MatRegisterDynamic(MATSUPERLU, path,"MatCreate_SuperLU",MatCreate_SuperLU);
158: #endif
159: #if defined(PETSC_HAVE_SUPERLU_DIST)
160: MatRegisterDynamic(MATSUPERLU_DIST, path,"MatCreate_SuperLU_DIST",MatCreate_SuperLU_DIST);
161: #endif
162: #if defined(PETSC_HAVE_UMFPACK)
163: MatRegisterDynamic(MATUMFPACK, path,"MatCreate_UMFPACK",MatCreate_UMFPACK);
164: #endif
165: #if defined(PETSC_HAVE_ESSL) && !defined(PETSC_USE_COMPLEX) && !defined(PETSC_USE_SINGLE) && !defined(PETSC_USE_MAT_SINGLE)
166: MatRegisterDynamic(MATESSL, path,"MatCreate_Essl",MatCreate_Essl);
167: #endif
168: #if defined(PETSC_HAVE_LUSOL)
169: MatRegisterDynamic(MATLUSOL, path,"MatCreate_LUSOL",MatCreate_LUSOL);
170: #endif
171: #if defined(PETSC_HAVE_MUMPS)
172: MatRegisterDynamic(MATAIJMUMPS, path,"MatCreate_AIJMUMPS",MatCreate_AIJMUMPS);
173: MatRegisterDynamic(MATSBAIJMUMPS, path,"MatCreate_SBAIJMUMPS",MatCreate_SBAIJMUMPS);
174: #endif
175: #if defined(PETSC_HAVE_DSCPACK)
176: MatRegisterDynamic(MATDSCPACK, path,"MatCreate_DSCPACK",MatCreate_DSCPACK);
177: #endif
178: #if defined(PETSC_HAVE_MATLAB)
179: MatRegisterDynamic(MATMATLAB, path,"MatCreate_Matlab",MatCreate_Matlab);
180: #endif
181: #if defined(PETSC_HAVE_PLAPACK)
182: MatRegisterDynamic(MATPLAPACK, path,"MatCreate_Plapack",MatCreate_Plapack);
183: #endif
184: return(0);
185: }