xref: /petsc/src/mat/interface/matregis.c (revision 7453f77509fc006cbcc7de2dd772f60dc49feac5)
1 
2 #include <petsc/private/matimpl.h>  /*I "petscmat.h" I*/
3 
4 PETSC_EXTERN PetscErrorCode MatCreate_MFFD(Mat);
5 PETSC_EXTERN PetscErrorCode MatCreate_MAIJ(Mat);
6 PETSC_EXTERN PetscErrorCode MatCreate_IS(Mat);
7 
8 PETSC_EXTERN PetscErrorCode MatCreate_SeqAIJ(Mat);
9 PETSC_EXTERN PetscErrorCode MatCreate_MPIAIJ(Mat);
10 
11 PETSC_EXTERN PetscErrorCode MatCreate_SeqBAIJ(Mat);
12 PETSC_EXTERN PetscErrorCode MatCreate_MPIBAIJ(Mat);
13 
14 PETSC_EXTERN PetscErrorCode MatCreate_SeqSBAIJ(Mat);
15 PETSC_EXTERN PetscErrorCode MatCreate_MPISBAIJ(Mat);
16 
17 PETSC_EXTERN PetscErrorCode MatCreate_SeqDense(Mat);
18 PETSC_EXTERN PetscErrorCode MatCreate_MPIDense(Mat);
19 
20 PETSC_EXTERN PetscErrorCode MatCreate_MPIAdj(Mat);
21 PETSC_EXTERN PetscErrorCode MatCreate_Shell(Mat);
22 PETSC_EXTERN PetscErrorCode MatCreate_Composite(Mat);
23 
24 PETSC_EXTERN PetscErrorCode MatCreate_SeqAIJPERM(Mat);
25 PETSC_EXTERN PetscErrorCode MatCreate_MPIAIJPERM(Mat);
26 
27 PETSC_EXTERN PetscErrorCode MatCreate_SeqAIJCRL(Mat);
28 PETSC_EXTERN PetscErrorCode MatCreate_MPIAIJCRL(Mat);
29 
30 PETSC_EXTERN PetscErrorCode MatCreate_Scatter(Mat);
31 PETSC_EXTERN PetscErrorCode MatCreate_BlockMat(Mat);
32 PETSC_EXTERN PetscErrorCode MatCreate_Nest(Mat);
33 
34 #if defined PETSC_HAVE_CUSP
35 PETSC_EXTERN PetscErrorCode MatCreate_SeqAIJCUSP(Mat);
36 PETSC_EXTERN PetscErrorCode MatCreate_MPIAIJCUSP(Mat);
37 #endif
38 
39 #if defined PETSC_HAVE_VECCUDA
40 PETSC_EXTERN PetscErrorCode MatCreate_SeqAIJCUSPARSE(Mat);
41 PETSC_EXTERN PetscErrorCode MatCreate_MPIAIJCUSPARSE(Mat);
42 #endif
43 
44 #if defined PETSC_HAVE_VIENNACL
45 PETSC_EXTERN PetscErrorCode MatCreate_SeqAIJViennaCL(Mat);
46 PETSC_EXTERN PetscErrorCode MatCreate_MPIAIJViennaCL(Mat);
47 #endif
48 
49 #if defined PETSC_HAVE_FFTW
50 PETSC_EXTERN PetscErrorCode MatCreate_FFTW(Mat);
51 #endif
52 PETSC_EXTERN PetscErrorCode MatCreate_Elemental(Mat);
53 
54 PETSC_EXTERN PetscErrorCode MatCreate_Preallocator(Mat);
55 
56 /*
57     This is used by MatSetType() to make sure that at least one
58     MatRegisterAll() is called. In general, if there is more than one
59     DLL, then MatRegisterAll() may be called several times.
60 */
61 extern PetscBool MatRegisterAllCalled;
62 
63 #undef __FUNCT__
64 #define __FUNCT__ "MatRegisterAll"
65 /*@C
66   MatRegisterAll - Registers all of the matrix types in PETSc
67 
68   Not Collective
69 
70   Level: advanced
71 
72 .keywords: KSP, register, all
73 
74 .seealso:  MatRegister()
75 @*/
76 PetscErrorCode  MatRegisterAll(void)
77 {
78   PetscErrorCode ierr;
79 
80   PetscFunctionBegin;
81   if (MatRegisterAllCalled) PetscFunctionReturn(0);
82   MatRegisterAllCalled = PETSC_TRUE;
83 
84   ierr = MatRegister(MATMFFD,           MatCreate_MFFD);CHKERRQ(ierr);
85 
86   ierr = MatRegister(MATMPIMAIJ,        MatCreate_MAIJ);CHKERRQ(ierr);
87   ierr = MatRegister(MATSEQMAIJ,        MatCreate_MAIJ);CHKERRQ(ierr);
88   ierr = MatRegister(MATMAIJ,           MatCreate_MAIJ);CHKERRQ(ierr);
89 
90   ierr = MatRegister(MATIS,             MatCreate_IS);CHKERRQ(ierr);
91   ierr = MatRegister(MATSHELL,          MatCreate_Shell);CHKERRQ(ierr);
92   ierr = MatRegister(MATCOMPOSITE,      MatCreate_Composite);CHKERRQ(ierr);
93 
94   ierr = MatRegisterBaseName(MATAIJ,MATSEQAIJ,MATMPIAIJ);CHKERRQ(ierr);
95   ierr = MatRegister(MATMPIAIJ,         MatCreate_MPIAIJ);CHKERRQ(ierr);
96   ierr = MatRegister(MATSEQAIJ,         MatCreate_SeqAIJ);CHKERRQ(ierr);
97 
98   ierr = MatRegisterBaseName(MATAIJPERM,MATSEQAIJPERM,MATMPIAIJPERM);CHKERRQ(ierr);
99   ierr = MatRegister(MATMPIAIJPERM,     MatCreate_MPIAIJPERM);CHKERRQ(ierr);
100   ierr = MatRegister(MATSEQAIJPERM,     MatCreate_SeqAIJPERM);CHKERRQ(ierr);
101 
102   ierr = MatRegisterBaseName(MATAIJCRL,MATSEQAIJCRL,MATMPIAIJCRL);CHKERRQ(ierr);
103   ierr = MatRegister(MATSEQAIJCRL,      MatCreate_SeqAIJCRL);CHKERRQ(ierr);
104   ierr = MatRegister(MATMPIAIJCRL,      MatCreate_MPIAIJCRL);CHKERRQ(ierr);
105 
106   ierr = MatRegisterBaseName(MATBAIJ,MATSEQBAIJ,MATMPIBAIJ);CHKERRQ(ierr);
107   ierr = MatRegister(MATMPIBAIJ,        MatCreate_MPIBAIJ);CHKERRQ(ierr);
108   ierr = MatRegister(MATSEQBAIJ,        MatCreate_SeqBAIJ);CHKERRQ(ierr);
109 
110   ierr = MatRegisterBaseName(MATSBAIJ,MATSEQSBAIJ,MATMPISBAIJ);CHKERRQ(ierr);
111   ierr = MatRegister(MATMPISBAIJ,       MatCreate_MPISBAIJ);CHKERRQ(ierr);
112   ierr = MatRegister(MATSEQSBAIJ,       MatCreate_SeqSBAIJ);CHKERRQ(ierr);
113 
114   ierr = MatRegisterBaseName(MATDENSE,MATSEQDENSE,MATMPIDENSE);CHKERRQ(ierr);
115   ierr = MatRegister(MATMPIDENSE,       MatCreate_MPIDense);CHKERRQ(ierr);
116   ierr = MatRegister(MATSEQDENSE,       MatCreate_SeqDense);CHKERRQ(ierr);
117 
118   ierr = MatRegister(MATMPIADJ,         MatCreate_MPIAdj);CHKERRQ(ierr);
119   ierr = MatRegister(MATSCATTER,        MatCreate_Scatter);CHKERRQ(ierr);
120   ierr = MatRegister(MATBLOCKMAT,       MatCreate_BlockMat);CHKERRQ(ierr);
121   ierr = MatRegister(MATNEST,           MatCreate_Nest);CHKERRQ(ierr);
122 
123 
124 #if defined PETSC_HAVE_CUSP
125   ierr = MatRegisterBaseName(MATAIJCUSP,MATSEQAIJCUSP,MATMPIAIJCUSP);CHKERRQ(ierr);
126   ierr = MatRegister(MATSEQAIJCUSP,     MatCreate_SeqAIJCUSP);CHKERRQ(ierr);
127   ierr = MatRegister(MATMPIAIJCUSP,     MatCreate_MPIAIJCUSP);CHKERRQ(ierr);
128 #endif
129 
130 #if defined PETSC_HAVE_VECCUDA
131   ierr = MatRegisterBaseName(MATAIJCUSPARSE,MATSEQAIJCUSPARSE,MATMPIAIJCUSPARSE);CHKERRQ(ierr);
132   ierr = MatRegister(MATSEQAIJCUSPARSE, MatCreate_SeqAIJCUSPARSE);CHKERRQ(ierr);
133   ierr = MatRegister(MATMPIAIJCUSPARSE, MatCreate_MPIAIJCUSPARSE);CHKERRQ(ierr);
134 #endif
135 
136 #if defined PETSC_HAVE_VIENNACL
137   ierr = MatRegisterBaseName(MATAIJVIENNACL,MATSEQAIJVIENNACL,MATMPIAIJVIENNACL);CHKERRQ(ierr);
138   ierr = MatRegister(MATSEQAIJVIENNACL, MatCreate_SeqAIJViennaCL);CHKERRQ(ierr);
139   ierr = MatRegister(MATMPIAIJVIENNACL, MatCreate_MPIAIJViennaCL);CHKERRQ(ierr);
140 #endif
141 
142 
143 #if defined PETSC_HAVE_FFTW
144   ierr = MatRegister(MATFFTW,           MatCreate_FFTW);CHKERRQ(ierr);
145 #endif
146 #if defined PETSC_HAVE_ELEMENTAL
147   ierr = MatRegister(MATELEMENTAL,      MatCreate_Elemental);CHKERRQ(ierr);
148 #endif
149 
150   ierr = MatRegister(MATPREALLOCATOR,   MatCreate_Preallocator);CHKERRQ(ierr);
151   PetscFunctionReturn(0);
152 }
153 
154 
155