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 @*/ 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 @*/ 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 @*/ 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 @*/ 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 @*/ 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 @*/ 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