xref: /petsc/src/dm/interface/dmregall.c (revision 1ebf93c6b7d760d592de6ebe6cdc0debaa3caf75)
1 
2 #include <petscdm.h>     /*I  "petscdm.h"  I*/
3 #include <petscdmplex.h> /*I  "petscdmplex.h"  I*/
4 #include <petsc/private/dmimpl.h>
5 #include <petsc/private/dmpleximpl.h>
6 #include <petsc/private/petscfeimpl.h>
7 #include <petsc/private/petscfvimpl.h>
8 #include <petsc/private/petscdsimpl.h>
9 PETSC_EXTERN PetscErrorCode DMCreate_DA(DM);
10 PETSC_EXTERN PetscErrorCode DMCreate_Composite(DM);
11 PETSC_EXTERN PetscErrorCode DMCreate_Sliced(DM);
12 PETSC_EXTERN PetscErrorCode DMCreate_Shell(DM);
13 PETSC_EXTERN PetscErrorCode DMCreate_Redundant(DM);
14 PETSC_EXTERN PetscErrorCode DMCreate_Plex(DM);
15 PETSC_EXTERN PetscErrorCode DMCreate_Patch(DM);
16 #if defined(PETSC_HAVE_MOAB)
17 PETSC_EXTERN PetscErrorCode DMCreate_Moab(DM);
18 #endif
19 PETSC_EXTERN PetscErrorCode DMCreate_Network(DM);
20 PETSC_EXTERN PetscErrorCode DMCreate_Forest(DM);
21 #if defined(PETSC_HAVE_P4EST)
22 PETSC_EXTERN PetscErrorCode DMCreate_p4est(DM);
23 PETSC_EXTERN PetscErrorCode DMCreate_p8est(DM);
24 #endif
25 
26 #undef __FUNCT__
27 #define __FUNCT__ "DMRegisterAll"
28 /*@C
29   DMRegisterAll - Registers all of the DM components in the DM package.
30 
31   Not Collective
32 
33   Input parameter:
34 . path - The dynamic library path
35 
36   Level: advanced
37 
38 .keywords: DM, register, all
39 .seealso:  DMRegister(), DMRegisterDestroy()
40 @*/
41 PetscErrorCode  DMRegisterAll()
42 {
43   PetscErrorCode ierr;
44 
45   PetscFunctionBegin;
46   if (DMRegisterAllCalled) PetscFunctionReturn(0);
47   DMRegisterAllCalled = PETSC_TRUE;
48 
49   ierr = DMRegister(DMDA,         DMCreate_DA);CHKERRQ(ierr);
50   ierr = DMRegister(DMCOMPOSITE,  DMCreate_Composite);CHKERRQ(ierr);
51   ierr = DMRegister(DMSLICED,     DMCreate_Sliced);CHKERRQ(ierr);
52   ierr = DMRegister(DMSHELL,      DMCreate_Shell);CHKERRQ(ierr);
53   ierr = DMRegister(DMREDUNDANT,  DMCreate_Redundant);CHKERRQ(ierr);
54   ierr = DMRegister(DMPLEX,       DMCreate_Plex);CHKERRQ(ierr);
55   ierr = DMRegister(DMPATCH,      DMCreate_Patch);CHKERRQ(ierr);
56 #if defined(PETSC_HAVE_MOAB)
57   ierr = DMRegister(DMMOAB,       DMCreate_Moab);CHKERRQ(ierr);
58 #endif
59   ierr = DMRegister(DMNETWORK,    DMCreate_Network);CHKERRQ(ierr);
60   ierr = DMRegister(DMFOREST,     DMCreate_Forest);CHKERRQ(ierr);
61 #if defined(PETSC_HAVE_P4EST)
62   ierr = DMRegister(DMP4EST,      DMCreate_p4est);CHKERRQ(ierr);
63   ierr = DMRegister(DMP8EST,      DMCreate_p8est);CHKERRQ(ierr);
64 #endif
65   PetscFunctionReturn(0);
66 }
67 
68 PETSC_EXTERN PetscErrorCode PetscPartitionerCreate_Chaco(PetscPartitioner);
69 PETSC_EXTERN PetscErrorCode PetscPartitionerCreate_ParMetis(PetscPartitioner);
70 PETSC_EXTERN PetscErrorCode PetscPartitionerCreate_Shell(PetscPartitioner);
71 PETSC_EXTERN PetscErrorCode PetscPartitionerCreate_Simple(PetscPartitioner);
72 PETSC_EXTERN PetscErrorCode PetscPartitionerCreate_Gather(PetscPartitioner);
73 
74 #undef __FUNCT__
75 #define __FUNCT__ "PetscPartitionerRegisterAll"
76 /*@C
77   PetscPartitionerRegisterAll - Registers all of the PetscPartitioner components in the DM package.
78 
79   Not Collective
80 
81   Input parameter:
82 . path - The dynamic library path
83 
84   Level: advanced
85 
86 .keywords: PetscPartitioner, register, all
87 .seealso:  PetscPartitionerRegister(), PetscPartitionerRegisterDestroy()
88 @*/
89 PetscErrorCode PetscPartitionerRegisterAll()
90 {
91   PetscErrorCode ierr;
92 
93   PetscFunctionBegin;
94   if (PetscPartitionerRegisterAllCalled) PetscFunctionReturn(0);
95   PetscPartitionerRegisterAllCalled = PETSC_TRUE;
96 
97   ierr = PetscPartitionerRegister(PETSCPARTITIONERCHACO,    PetscPartitionerCreate_Chaco);CHKERRQ(ierr);
98   ierr = PetscPartitionerRegister(PETSCPARTITIONERPARMETIS, PetscPartitionerCreate_ParMetis);CHKERRQ(ierr);
99   ierr = PetscPartitionerRegister(PETSCPARTITIONERSHELL,    PetscPartitionerCreate_Shell);CHKERRQ(ierr);
100   ierr = PetscPartitionerRegister(PETSCPARTITIONERSIMPLE,   PetscPartitionerCreate_Simple);CHKERRQ(ierr);
101   ierr = PetscPartitionerRegister(PETSCPARTITIONERGATHER,   PetscPartitionerCreate_Gather);CHKERRQ(ierr);
102   PetscFunctionReturn(0);
103 }
104 #include <petscfe.h>     /*I  "petscfe.h"  I*/
105 
106 PETSC_EXTERN PetscErrorCode PetscSpaceCreate_Polynomial(PetscSpace);
107 PETSC_EXTERN PetscErrorCode PetscSpaceCreate_DG(PetscSpace);
108 
109 #undef __FUNCT__
110 #define __FUNCT__ "PetscSpaceRegisterAll"
111 /*@C
112   PetscSpaceRegisterAll - Registers all of the PetscSpace components in the PetscFE package.
113 
114   Not Collective
115 
116   Input parameter:
117 . path - The dynamic library path
118 
119   Level: advanced
120 
121 .keywords: PetscSpace, register, all
122 .seealso:  PetscSpaceRegister(), PetscSpaceRegisterDestroy()
123 @*/
124 PetscErrorCode PetscSpaceRegisterAll()
125 {
126   PetscErrorCode ierr;
127 
128   PetscFunctionBegin;
129   if (PetscSpaceRegisterAllCalled) PetscFunctionReturn(0);
130   PetscSpaceRegisterAllCalled = PETSC_TRUE;
131 
132   ierr = PetscSpaceRegister(PETSCSPACEPOLYNOMIAL, PetscSpaceCreate_Polynomial);CHKERRQ(ierr);
133   ierr = PetscSpaceRegister(PETSCSPACEDG,         PetscSpaceCreate_DG);CHKERRQ(ierr);
134   PetscFunctionReturn(0);
135 }
136 
137 PETSC_EXTERN PetscErrorCode PetscDualSpaceCreate_Lagrange(PetscDualSpace);
138 PETSC_EXTERN PetscErrorCode PetscDualSpaceCreate_Simple(PetscDualSpace);
139 
140 #undef __FUNCT__
141 #define __FUNCT__ "PetscDualSpaceRegisterAll"
142 /*@C
143   PetscDualSpaceRegisterAll - Registers all of the PetscDualSpace components in the PetscFE package.
144 
145   Not Collective
146 
147   Input parameter:
148 . path - The dynamic library path
149 
150   Level: advanced
151 
152 .keywords: PetscDualSpace, register, all
153 .seealso:  PetscDualSpaceRegister(), PetscDualSpaceRegisterDestroy()
154 @*/
155 PetscErrorCode PetscDualSpaceRegisterAll()
156 {
157   PetscErrorCode ierr;
158 
159   PetscFunctionBegin;
160   if (PetscDualSpaceRegisterAllCalled) PetscFunctionReturn(0);
161   PetscDualSpaceRegisterAllCalled = PETSC_TRUE;
162 
163   ierr = PetscDualSpaceRegister(PETSCDUALSPACELAGRANGE, PetscDualSpaceCreate_Lagrange);CHKERRQ(ierr);
164   ierr = PetscDualSpaceRegister(PETSCDUALSPACESIMPLE,   PetscDualSpaceCreate_Simple);CHKERRQ(ierr);
165   PetscFunctionReturn(0);
166 }
167 
168 PETSC_EXTERN PetscErrorCode PetscFECreate_Basic(PetscFE);
169 PETSC_EXTERN PetscErrorCode PetscFECreate_Nonaffine(PetscFE);
170 PETSC_EXTERN PetscErrorCode PetscFECreate_Composite(PetscFE);
171 #ifdef PETSC_HAVE_OPENCL
172 PETSC_EXTERN PetscErrorCode PetscFECreate_OpenCL(PetscFE);
173 #endif
174 
175 #undef __FUNCT__
176 #define __FUNCT__ "PetscFERegisterAll"
177 /*@C
178   PetscFERegisterAll - Registers all of the PetscFE components in the PetscFE package.
179 
180   Not Collective
181 
182   Input parameter:
183 . path - The dynamic library path
184 
185   Level: advanced
186 
187 .keywords: PetscFE, register, all
188 .seealso:  PetscFERegister(), PetscFERegisterDestroy()
189 @*/
190 PetscErrorCode PetscFERegisterAll()
191 {
192   PetscErrorCode ierr;
193 
194   PetscFunctionBegin;
195   if (PetscFERegisterAllCalled) PetscFunctionReturn(0);
196   PetscFERegisterAllCalled = PETSC_TRUE;
197 
198   ierr = PetscFERegister(PETSCFEBASIC,     PetscFECreate_Basic);CHKERRQ(ierr);
199   ierr = PetscFERegister(PETSCFENONAFFINE, PetscFECreate_Nonaffine);CHKERRQ(ierr);
200   ierr = PetscFERegister(PETSCFECOMPOSITE, PetscFECreate_Composite);CHKERRQ(ierr);
201 #ifdef PETSC_HAVE_OPENCL
202   ierr = PetscFERegister(PETSCFEOPENCL, PetscFECreate_OpenCL);CHKERRQ(ierr);
203 #endif
204   PetscFunctionReturn(0);
205 }
206 #include <petscfv.h>     /*I  "petscfv.h"  I*/
207 
208 PETSC_EXTERN PetscErrorCode PetscLimiterCreate_Sin(PetscLimiter);
209 PETSC_EXTERN PetscErrorCode PetscLimiterCreate_Zero(PetscLimiter);
210 PETSC_EXTERN PetscErrorCode PetscLimiterCreate_None(PetscLimiter);
211 PETSC_EXTERN PetscErrorCode PetscLimiterCreate_Minmod(PetscLimiter);
212 PETSC_EXTERN PetscErrorCode PetscLimiterCreate_VanLeer(PetscLimiter);
213 PETSC_EXTERN PetscErrorCode PetscLimiterCreate_VanAlbada(PetscLimiter);
214 PETSC_EXTERN PetscErrorCode PetscLimiterCreate_Superbee(PetscLimiter);
215 PETSC_EXTERN PetscErrorCode PetscLimiterCreate_MC(PetscLimiter);
216 
217 #undef __FUNCT__
218 #define __FUNCT__ "PetscLimiterRegisterAll"
219 /*@C
220   PetscLimiterRegisterAll - Registers all of the PetscLimiter components in the PetscFV package.
221 
222   Not Collective
223 
224   Input parameter:
225 . path - The dynamic library path
226 
227   Level: advanced
228 
229 .keywords: PetscLimiter, register, all
230 .seealso:  PetscLimiterRegister(), PetscLimiterRegisterDestroy()
231 @*/
232 PetscErrorCode PetscLimiterRegisterAll()
233 {
234   PetscErrorCode ierr;
235 
236   PetscFunctionBegin;
237   if (PetscLimiterRegisterAllCalled) PetscFunctionReturn(0);
238   PetscLimiterRegisterAllCalled = PETSC_TRUE;
239 
240   ierr = PetscLimiterRegister(PETSCLIMITERSIN,       PetscLimiterCreate_Sin);CHKERRQ(ierr);
241   ierr = PetscLimiterRegister(PETSCLIMITERZERO,      PetscLimiterCreate_Zero);CHKERRQ(ierr);
242   ierr = PetscLimiterRegister(PETSCLIMITERNONE,      PetscLimiterCreate_None);CHKERRQ(ierr);
243   ierr = PetscLimiterRegister(PETSCLIMITERMINMOD,    PetscLimiterCreate_Minmod);CHKERRQ(ierr);
244   ierr = PetscLimiterRegister(PETSCLIMITERVANLEER,   PetscLimiterCreate_VanLeer);CHKERRQ(ierr);
245   ierr = PetscLimiterRegister(PETSCLIMITERVANALBADA, PetscLimiterCreate_VanAlbada);CHKERRQ(ierr);
246   ierr = PetscLimiterRegister(PETSCLIMITERSUPERBEE,  PetscLimiterCreate_Superbee);CHKERRQ(ierr);
247   ierr = PetscLimiterRegister(PETSCLIMITERMC,        PetscLimiterCreate_MC);CHKERRQ(ierr);
248   PetscFunctionReturn(0);
249 }
250 
251 PETSC_EXTERN PetscErrorCode PetscFVCreate_Upwind(PetscFV);
252 PETSC_EXTERN PetscErrorCode PetscFVCreate_LeastSquares(PetscFV);
253 
254 #undef __FUNCT__
255 #define __FUNCT__ "PetscFVRegisterAll"
256 /*@C
257   PetscFVRegisterAll - Registers all of the PetscFV components in the PetscFV package.
258 
259   Not Collective
260 
261   Input parameter:
262 . path - The dynamic library path
263 
264   Level: advanced
265 
266 .keywords: PetscFV, register, all
267 .seealso:  PetscFVRegister(), PetscFVRegisterDestroy()
268 @*/
269 PetscErrorCode PetscFVRegisterAll()
270 {
271   PetscErrorCode ierr;
272 
273   PetscFunctionBegin;
274   if (PetscFVRegisterAllCalled) PetscFunctionReturn(0);
275   PetscFVRegisterAllCalled = PETSC_TRUE;
276 
277   ierr = PetscFVRegister(PETSCFVUPWIND,       PetscFVCreate_Upwind);CHKERRQ(ierr);
278   ierr = PetscFVRegister(PETSCFVLEASTSQUARES, PetscFVCreate_LeastSquares);CHKERRQ(ierr);
279   PetscFunctionReturn(0);
280 }
281 #include <petscds.h>     /*I  "petscds.h"  I*/
282 
283 PETSC_EXTERN PetscErrorCode PetscDSCreate_Basic(PetscDS);
284 
285 #undef __FUNCT__
286 #define __FUNCT__ "PetscDSRegisterAll"
287 /*@C
288   PetscDSRegisterAll - Registers all of the PetscDS components in the PetscDS package.
289 
290   Not Collective
291 
292   Input parameter:
293 . path - The dynamic library path
294 
295   Level: advanced
296 
297 .keywords: PetscDS, register, all
298 .seealso:  PetscDSRegister(), PetscDSRegisterDestroy()
299 @*/
300 PetscErrorCode PetscDSRegisterAll()
301 {
302   PetscErrorCode ierr;
303 
304   PetscFunctionBegin;
305   if (PetscDSRegisterAllCalled) PetscFunctionReturn(0);
306   PetscDSRegisterAllCalled = PETSC_TRUE;
307 
308   ierr = PetscDSRegister(PETSCDSBASIC, PetscDSCreate_Basic);CHKERRQ(ierr);
309   PetscFunctionReturn(0);
310 }
311