xref: /petsc/src/vec/is/ao/interface/aoreg.c (revision 8a7d4057d9226490dba4e1a062f54f84e7d90861) !
11447629fSBarry Smith #include <../src/vec/is/ao/aoimpl.h> /*I "petscao.h"  I*/
21447629fSBarry Smith 
3da8c939bSJacob Faibussowitsch static PetscBool AOPackageInitialized = PETSC_FALSE;
4da8c939bSJacob Faibussowitsch static PetscBool AORegisterAllCalled  = PETSC_FALSE;
5da8c939bSJacob Faibussowitsch 
6da8c939bSJacob Faibussowitsch /*@C
7da8c939bSJacob Faibussowitsch   AOFinalizePackage - This function finalizes everything in the `AO` package. It is called
8da8c939bSJacob Faibussowitsch   from `PetscFinalize()`.
9da8c939bSJacob Faibussowitsch 
10da8c939bSJacob Faibussowitsch   Level: developer
11da8c939bSJacob Faibussowitsch 
12da8c939bSJacob Faibussowitsch .seealso: `AOInitializePackage()`, `PetscInitialize()`
13da8c939bSJacob Faibussowitsch @*/
AOFinalizePackage(void)14da8c939bSJacob Faibussowitsch PetscErrorCode AOFinalizePackage(void)
15da8c939bSJacob Faibussowitsch {
16da8c939bSJacob Faibussowitsch   PetscFunctionBegin;
17da8c939bSJacob Faibussowitsch   PetscCall(PetscFunctionListDestroy(&AOList));
18da8c939bSJacob Faibussowitsch   AOPackageInitialized = PETSC_FALSE;
19da8c939bSJacob Faibussowitsch   AORegisterAllCalled  = PETSC_FALSE;
20da8c939bSJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
21da8c939bSJacob Faibussowitsch }
22da8c939bSJacob Faibussowitsch 
23da8c939bSJacob Faibussowitsch /*@C
24da8c939bSJacob Faibussowitsch   AOInitializePackage - This function initializes everything in the `AO` package. It is called
25da8c939bSJacob Faibussowitsch   from `PetscDLLibraryRegister_petscvec()` when using dynamic libraries, and on the first call to `AOCreate()`
26da8c939bSJacob Faibussowitsch   when using static or shared libraries.
27da8c939bSJacob Faibussowitsch 
28da8c939bSJacob Faibussowitsch   Level: developer
29da8c939bSJacob Faibussowitsch 
30da8c939bSJacob Faibussowitsch .seealso: `AOFinalizePackage()`, `PetscInitialize()`
31da8c939bSJacob Faibussowitsch @*/
AOInitializePackage(void)32da8c939bSJacob Faibussowitsch PetscErrorCode AOInitializePackage(void)
33da8c939bSJacob Faibussowitsch {
34da8c939bSJacob Faibussowitsch   char      logList[256];
35da8c939bSJacob Faibussowitsch   PetscBool opt, pkg;
36da8c939bSJacob Faibussowitsch 
37da8c939bSJacob Faibussowitsch   PetscFunctionBegin;
38da8c939bSJacob Faibussowitsch   if (AOPackageInitialized) PetscFunctionReturn(PETSC_SUCCESS);
39da8c939bSJacob Faibussowitsch   AOPackageInitialized = PETSC_TRUE;
40da8c939bSJacob Faibussowitsch   /* Register Classes */
41da8c939bSJacob Faibussowitsch   PetscCall(PetscClassIdRegister("Application Order", &AO_CLASSID));
42da8c939bSJacob Faibussowitsch   /* Register Constructors */
43da8c939bSJacob Faibussowitsch   PetscCall(AORegisterAll());
44da8c939bSJacob Faibussowitsch   /* Register Events */
45da8c939bSJacob Faibussowitsch   PetscCall(PetscLogEventRegister("AOPetscToApplication", AO_CLASSID, &AO_PetscToApplication));
46da8c939bSJacob Faibussowitsch   PetscCall(PetscLogEventRegister("AOApplicationToPetsc", AO_CLASSID, &AO_ApplicationToPetsc));
47da8c939bSJacob Faibussowitsch   /* Process Info */
48da8c939bSJacob Faibussowitsch   {
49da8c939bSJacob Faibussowitsch     PetscClassId classids[1];
50da8c939bSJacob Faibussowitsch 
51da8c939bSJacob Faibussowitsch     classids[0] = AO_CLASSID;
52da8c939bSJacob Faibussowitsch     PetscCall(PetscInfoProcessClass("ao", 1, classids));
53da8c939bSJacob Faibussowitsch   }
54da8c939bSJacob Faibussowitsch   /* Process summary exclusions */
55da8c939bSJacob Faibussowitsch   PetscCall(PetscOptionsGetString(NULL, NULL, "-log_exclude", logList, sizeof(logList), &opt));
56da8c939bSJacob Faibussowitsch   if (opt) {
57da8c939bSJacob Faibussowitsch     PetscCall(PetscStrInList("ao", logList, ',', &pkg));
58da8c939bSJacob Faibussowitsch     if (pkg) PetscCall(PetscLogEventExcludeClass(AO_CLASSID));
59da8c939bSJacob Faibussowitsch   }
60da8c939bSJacob Faibussowitsch   /* Register package finalizer */
61da8c939bSJacob Faibussowitsch   PetscCall(PetscRegisterFinalize(AOFinalizePackage));
62da8c939bSJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
63da8c939bSJacob Faibussowitsch }
641447629fSBarry Smith 
65*cc4c1da9SBarry Smith /*@
66cab54364SBarry Smith   AOSetType - Builds an application ordering for a particular `AOType`
671447629fSBarry Smith 
68c3339decSBarry Smith   Collective
691447629fSBarry Smith 
701447629fSBarry Smith   Input Parameters:
71cab54364SBarry Smith + ao     - The `AO` object
721447629fSBarry Smith - method - The name of the AO type
731447629fSBarry Smith 
741447629fSBarry Smith   Options Database Key:
75cab54364SBarry Smith . -ao_type <type> - Sets the `AO` type; use -help for a list of available types
761447629fSBarry Smith 
771447629fSBarry Smith   Level: intermediate
781447629fSBarry Smith 
79cab54364SBarry Smith   Notes:
80cab54364SBarry Smith   See "petsc/include/petscao.h" for available AO types (for instance, `AOBASIC` and `AOMEMORYSCALABLE`).
81cab54364SBarry Smith 
82cab54364SBarry Smith   `AO` are usually created via the convenience routines such as `AOCreateBasic()` or `AOCreateMemoryScalable()`
83cab54364SBarry Smith 
84cab54364SBarry Smith .seealso: `AO`, `AOType`, `AOCreateBasic()`, `AOCreateMemoryScalable()`, `AOGetType()`, `AOCreate()`
851447629fSBarry Smith @*/
AOSetType(AO ao,AOType method)86d71ae5a4SJacob Faibussowitsch PetscErrorCode AOSetType(AO ao, AOType method)
87d71ae5a4SJacob Faibussowitsch {
881447629fSBarry Smith   PetscErrorCode (*r)(AO);
891447629fSBarry Smith   PetscBool match;
901447629fSBarry Smith 
911447629fSBarry Smith   PetscFunctionBegin;
921447629fSBarry Smith   PetscValidHeaderSpecific(ao, AO_CLASSID, 1);
939566063dSJacob Faibussowitsch   PetscCall(PetscObjectTypeCompare((PetscObject)ao, method, &match));
943ba16761SJacob Faibussowitsch   if (match) PetscFunctionReturn(PETSC_SUCCESS);
951447629fSBarry Smith 
969566063dSJacob Faibussowitsch   PetscCall(AORegisterAll());
979566063dSJacob Faibussowitsch   PetscCall(PetscFunctionListFind(AOList, method, &r));
986adde796SStefano Zampini   PetscCheck(r, PetscObjectComm((PetscObject)ao), PETSC_ERR_ARG_UNKNOWN_TYPE, "Unknown AO type: %s", method);
99dbbe0bcdSBarry Smith   PetscTryTypeMethod(ao, destroy);
1001447629fSBarry Smith   ao->ops->destroy = NULL;
1011447629fSBarry Smith 
1029566063dSJacob Faibussowitsch   PetscCall((*r)(ao));
1033ba16761SJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
1041447629fSBarry Smith }
1051447629fSBarry Smith 
106*cc4c1da9SBarry Smith /*@
107cab54364SBarry Smith   AOGetType - Gets the `AO` type name (as a string) from the AO.
1081447629fSBarry Smith 
1091447629fSBarry Smith   Not Collective
1101447629fSBarry Smith 
1111447629fSBarry Smith   Input Parameter:
1121447629fSBarry Smith . ao - The vector
1131447629fSBarry Smith 
1141447629fSBarry Smith   Output Parameter:
115cab54364SBarry Smith . type - The `AO` type name
1161447629fSBarry Smith 
1171447629fSBarry Smith   Level: intermediate
1181447629fSBarry Smith 
119cab54364SBarry Smith .seealso: `AO`, `AOType`, `AOSetType()`, `AOCreate()`
1201447629fSBarry Smith @*/
AOGetType(AO ao,AOType * type)121d71ae5a4SJacob Faibussowitsch PetscErrorCode AOGetType(AO ao, AOType *type)
122d71ae5a4SJacob Faibussowitsch {
1231447629fSBarry Smith   PetscFunctionBegin;
1241447629fSBarry Smith   PetscValidHeaderSpecific(ao, AO_CLASSID, 1);
1254f572ea9SToby Isaac   PetscAssertPointer(type, 2);
1269566063dSJacob Faibussowitsch   PetscCall(AORegisterAll());
1271447629fSBarry Smith   *type = ((PetscObject)ao)->type_name;
1283ba16761SJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
1291447629fSBarry Smith }
1301447629fSBarry Smith 
131da8c939bSJacob Faibussowitsch PetscFunctionList AOList = NULL;
132da8c939bSJacob Faibussowitsch 
1331447629fSBarry Smith /*@C
1341d36bdfdSBarry Smith   AORegister - Register  an application ordering method
1351d36bdfdSBarry Smith 
136*cc4c1da9SBarry Smith   Not Collective, No Fortran Support
1371d36bdfdSBarry Smith 
1381d36bdfdSBarry Smith   Input Parameters:
139cab54364SBarry Smith + sname    - the name (`AOType`) of the `AO` scheme
1401d36bdfdSBarry Smith - function - the create routine for the application ordering method
1411447629fSBarry Smith 
1421447629fSBarry Smith   Level: advanced
1431d36bdfdSBarry Smith 
144cab54364SBarry Smith .seealso: `AO`, `AOType`, `AOCreate()`, `AORegisterAll()`, `AOBASIC`, `AOADVANCED`, `AOMAPPING`, `AOMEMORYSCALABLE`
1451447629fSBarry Smith @*/
AORegister(const char sname[],PetscErrorCode (* function)(AO))146d71ae5a4SJacob Faibussowitsch PetscErrorCode AORegister(const char sname[], PetscErrorCode (*function)(AO))
147d71ae5a4SJacob Faibussowitsch {
1481447629fSBarry Smith   PetscFunctionBegin;
1499566063dSJacob Faibussowitsch   PetscCall(AOInitializePackage());
1509566063dSJacob Faibussowitsch   PetscCall(PetscFunctionListAdd(&AOList, sname, function));
1513ba16761SJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
1521447629fSBarry Smith }
153da8c939bSJacob Faibussowitsch 
154da8c939bSJacob Faibussowitsch PETSC_INTERN PetscErrorCode AOCreate_Basic(AO ao);
155da8c939bSJacob Faibussowitsch PETSC_INTERN PetscErrorCode AOCreate_MemoryScalable(AO ao);
156da8c939bSJacob Faibussowitsch 
157da8c939bSJacob Faibussowitsch /*@C
158da8c939bSJacob Faibussowitsch   AORegisterAll - Registers all of the application ordering components in the `AO` package.
159da8c939bSJacob Faibussowitsch 
160da8c939bSJacob Faibussowitsch   Not Collective
161da8c939bSJacob Faibussowitsch 
162da8c939bSJacob Faibussowitsch   Level: advanced
163da8c939bSJacob Faibussowitsch 
164da8c939bSJacob Faibussowitsch .seealso: `AO`, `AOType`, `AORegister()`, `AORegisterDestroy()`
165da8c939bSJacob Faibussowitsch @*/
AORegisterAll(void)166da8c939bSJacob Faibussowitsch PetscErrorCode AORegisterAll(void)
167da8c939bSJacob Faibussowitsch {
168da8c939bSJacob Faibussowitsch   PetscFunctionBegin;
169da8c939bSJacob Faibussowitsch   if (AORegisterAllCalled) PetscFunctionReturn(PETSC_SUCCESS);
170da8c939bSJacob Faibussowitsch   AORegisterAllCalled = PETSC_TRUE;
171da8c939bSJacob Faibussowitsch 
172da8c939bSJacob Faibussowitsch   PetscCall(AORegister(AOBASIC, AOCreate_Basic));
173da8c939bSJacob Faibussowitsch   PetscCall(AORegister(AOMEMORYSCALABLE, AOCreate_MemoryScalable));
174da8c939bSJacob Faibussowitsch   PetscFunctionReturn(PETSC_SUCCESS);
175da8c939bSJacob Faibussowitsch }
176