1*b2487710SBarry Smith /* $Id: ao.h,v 1.13 1997/11/28 16:23:01 bsmith Exp bsmith $ */ 27588ac45SBarry Smith 3230e2716SBarry Smith /* 4230e2716SBarry Smith An application ordering is mapping between application-centric 57588ac45SBarry Smith ordering (the ordering that is "natural" to the application) and 67588ac45SBarry Smith the parallel ordering that PETSc uses. 77588ac45SBarry Smith */ 87588ac45SBarry Smith #if !defined(__AO_PACKAGE) 97588ac45SBarry Smith #define __AO_PACKAGE 107588ac45SBarry Smith #include "is.h" 11d64ed03dSBarry Smith #include "mat.h" 127588ac45SBarry Smith 130752156aSBarry Smith typedef enum {AO_BASIC=0, AO_ADVANCED=1} AOType; 147588ac45SBarry Smith 157588ac45SBarry Smith #define AO_COOKIE PETSC_COOKIE+20 167588ac45SBarry Smith 171ac94ccfSSatish Balay typedef struct _p_AO* AO; 187588ac45SBarry Smith 197588ac45SBarry Smith extern int AOCreateBasic(MPI_Comm,int,int*,int*,AO*); 20d64ed03dSBarry Smith extern int AOCreateBasicIS(IS,IS,AO*); 217588ac45SBarry Smith 227588ac45SBarry Smith extern int AOPetscToApplication(AO,int,int*); 237588ac45SBarry Smith extern int AOApplicationToPetsc(AO,int,int*); 247588ac45SBarry Smith extern int AOPetscToApplicationIS(AO,IS); 257588ac45SBarry Smith extern int AOApplicationToPetscIS(AO,IS); 267588ac45SBarry Smith 277588ac45SBarry Smith extern int AODestroy(AO); 287588ac45SBarry Smith extern int AOView(AO,Viewer); 297588ac45SBarry Smith 30376ee591SBarry Smith /* ----------------------------------------------------*/ 31376ee591SBarry Smith 320752156aSBarry Smith typedef enum {AODATA_BASIC=0, AODATA_ADVANCED=1} AODataType; 33376ee591SBarry Smith 340752156aSBarry Smith #define AODATA_COOKIE PETSC_COOKIE+24 35376ee591SBarry Smith 360752156aSBarry Smith typedef struct _p_AOData* AOData; 370752156aSBarry Smith 38522c5e43SBarry Smith extern int AODataCreateBasic(MPI_Comm,AOData *); 39522c5e43SBarry Smith extern int AODataView(AOData,Viewer); 40522c5e43SBarry Smith extern int AODataDestroy(AOData); 41522c5e43SBarry Smith extern int AODataLoadBasic(Viewer,AOData *); 42522c5e43SBarry Smith extern int AODataGetInfo(AOData,int*,char ***); 4331b6eecaSBarry Smith 44522c5e43SBarry Smith extern int AODataKeyAdd(AOData,char*,int,int); 45*b2487710SBarry Smith extern int AODataKeyRemove(AOData,char*); 46*b2487710SBarry Smith 47ea06a074SBarry Smith extern int AODataKeySetLocalToGlobalMapping(AOData,char*,ISLocalToGlobalMapping); 48ea06a074SBarry Smith extern int AODataKeyGetLocalToGlobalMapping(AOData,char*,ISLocalToGlobalMapping*); 49d64ed03dSBarry Smith extern int AODataKeyRemap(AOData,char *,AO); 5031b6eecaSBarry Smith 51ea06a074SBarry Smith extern int AODataKeyExists(AOData,char*,PetscTruth*); 52522c5e43SBarry Smith extern int AODataKeyGetInfo(AOData,char *,int *,int*,int*,char***); 53ea06a074SBarry Smith extern int AODataKeyGetOwnershipRange(AOData,char *,int *,int*); 54ea06a074SBarry Smith 55ea06a074SBarry Smith extern int AODataKeyGetNeighbors(AOData,char *,int,int*,IS *); 56ea06a074SBarry Smith extern int AODataKeyGetNeighborsIS(AOData,char *,IS,IS *); 57ea06a074SBarry Smith extern int AODataKeyGetAdjacency(AOData,char *,Mat*); 58ea06a074SBarry Smith 59ea06a074SBarry Smith extern int AODataKeyPartition(AOData,char *); 60ea06a074SBarry Smith 61e852ff30SBarry Smith extern int AODataSegmentAdd(AOData,char*,char *,int, int, int *,void *,PetscDataType); 62*b2487710SBarry Smith extern int AODataSegmentRemove(AOData,char *,char *); 63e852ff30SBarry Smith extern int AODataSegmentAddIS(AOData,char*,char *,int, IS,void *,PetscDataType); 6431b6eecaSBarry Smith 65ea06a074SBarry Smith extern int AODataSegmentExists(AOData,char*,char*,PetscTruth*); 66522c5e43SBarry Smith extern int AODataSegmentGetInfo(AOData,char *,char *,int *,PetscDataType*); 6731b6eecaSBarry Smith 68e852ff30SBarry Smith extern int AODataSegmentGet(AOData,char *,char *,int,int*,void **); 69e852ff30SBarry Smith extern int AODataSegmentRestore(AOData,char *,char *,int,int*,void **); 70e852ff30SBarry Smith extern int AODataSegmentGetIS(AOData,char *,char *,IS,void **); 71e852ff30SBarry Smith extern int AODataSegmentRestoreIS(AOData,char *,char *,IS,void **); 7231b6eecaSBarry Smith 73e852ff30SBarry Smith extern int AODataSegmentGetLocal(AOData,char *,char *,int,int*,void **); 74e852ff30SBarry Smith extern int AODataSegmentRestoreLocal(AOData,char *,char *,int,int*,void **); 75e852ff30SBarry Smith extern int AODataSegmentGetLocalIS(AOData,char *,char *,IS,void **); 76e852ff30SBarry Smith extern int AODataSegmentRestoreLocalIS(AOData,char *,char *,IS,void **); 772bdab257SBarry Smith 78e852ff30SBarry Smith extern int AODataSegmentGetReduced(AOData,char *,char *,int,int*,IS *); 79e852ff30SBarry Smith extern int AODataSegmentGetReducedIS(AOData,char *,char *,IS,IS *); 80ea06a074SBarry Smith extern int AODataSegmentGetExtrema(AOData,char*,char*,void *,void *); 81e852ff30SBarry Smith 82ea06a074SBarry Smith extern int AODataSegmentPartition(AOData,char *,char *); 832bdab257SBarry Smith 84376ee591SBarry Smith 857588ac45SBarry Smith #endif 867588ac45SBarry Smith 87230e2716SBarry Smith 88