4: #include <petsc/private/matimpl.h> 6: /* 7: MATMPIAdj format - Compressed row storage for storing adjacency lists, and possibly weights 8: This is for grid reorderings (to reduce bandwidth) 9: grid partitionings, etc. This is NOT currently a dynamic data-structure. 11: */ 13: typedef struct { 14: PetscInt nz; 15: PetscInt *diag; /* pointers to diagonal elements, if they exist */ 16: PetscInt *i; /* pointer to beginning of each row */ 17: PetscInt *j; /* column values: j + i[k] is start of row k */ 18: PetscInt *values; /* numerical values */ 19: PetscBool useedgeweights; /* if edge weights are used */ 20: PetscBool symmetric; /* user indicates the nonzero structure is symmetric */ 21: PetscBool freeaij; /* free a, i,j at destroy */ 22: PetscBool freeaijwithfree; /* use free() to free i,j instead of PetscFree() */ 23: PetscScalar *rowvalues; /* scalar work space for MatGetRow() */ 24: PetscInt rowvalues_alloc; 25: } Mat_MPIAdj; 27: #endif