147d993e7Ssuyashtn /* Portions of this code are under: 247d993e7Ssuyashtn Copyright (c) 2022 Advanced Micro Devices, Inc. All rights reserved. 347d993e7Ssuyashtn */ 4af0996ceSBarry Smith #include <petsc/private/matimpl.h> 51153da11SBarry Smith 69371c9d4SSatish Balay const char *MatOptions_Shifted[] = {"UNUSED_NONZERO_LOCATION_ERR", "ROW_ORIENTED", "NOT_A_VALID_OPTION", "SYMMETRIC", "STRUCTURALLY_SYMMETRIC", "FORCE_DIAGONAL_ENTRIES", "IGNORE_OFF_PROC_ENTRIES", "USE_HASH_TABLE", "KEEP_NONZERO_PATTERN", "IGNORE_ZERO_ENTRIES", "USE_INODES", "HERMITIAN", "SYMMETRY_ETERNAL", "NEW_NONZERO_LOCATION_ERR", "IGNORE_LOWER_TRIANGULAR", "ERROR_LOWER_TRIANGULAR", "GETROW_UPPERTRIANGULAR", "SPD", "NO_OFF_PROC_ZERO_ROWS", "NO_OFF_PROC_ENTRIES", "NEW_NONZERO_LOCATIONS", "NEW_NONZERO_ALLOCATION_ERR", "SUBSET_OFF_PROC_ENTRIES", "SUBMAT_SINGLEIS", "STRUCTURE_ONLY", "SORTED_FULL", "FORM_EXPLICIT_TRANSPOSE", "STRUCTURAL_SYMMETRY_ETERNAL", "SPD_ETERNAL", "MatOption", "MAT_", NULL}; 70f8fb01aSBarry Smith const char *const *MatOptions = MatOptions_Shifted + 2; 8f4259b30SLisandro Dalcin const char *const MatFactorShiftTypes[] = {"NONE", "NONZERO", "POSITIVE_DEFINITE", "INBLOCKS", "MatFactorShiftType", "PC_FACTOR_", NULL}; 9e6cbab7dSPierre Jolivet const char *const MatStructures[] = {"DIFFERENT", "SUBSET", "SAME", "UNKNOWN", "MatStructure", "MAT_STRUCTURE_", NULL}; 105e9742b9SJed Brown const char *const MatFactorShiftTypesDetail[] = {NULL, "diagonal shift to prevent zero pivot", "Manteuffel shift", "diagonal shift on blocks to prevent zero pivot"}; 11f4259b30SLisandro Dalcin const char *const MPPTScotchStrategyTypes[] = {"DEFAULT", "QUALITY", "SPEED", "BALANCE", "SAFETY", "SCALABILITY", "MPPTScotchStrategyType", "MP_PTSCOTCH_", NULL}; 12f4259b30SLisandro Dalcin const char *const MPChacoGlobalTypes[] = {"", "MULTILEVEL", "SPECTRAL", "", "LINEAR", "RANDOM", "SCATTERED", "MPChacoGlobalType", "MP_CHACO_", NULL}; 13f4259b30SLisandro Dalcin const char *const MPChacoLocalTypes[] = {"", "KERNIGHAN", "NONE", "MPChacoLocalType", "MP_CHACO_", NULL}; 14f4259b30SLisandro Dalcin const char *const MPChacoEigenTypes[] = {"LANCZOS", "RQI", "MPChacoEigenType", "MP_CHACO_", NULL}; 15290bbb0aSBarry Smith 16607a6623SBarry Smith extern PetscErrorCode MatMFFDInitializePackage(void); 173ca39a21SBarry Smith extern PetscErrorCode MatSolverTypeDestroy(void); 18ace3abfcSBarry Smith static PetscBool MatPackageInitialized = PETSC_FALSE; 1966976f2fSJacob Faibussowitsch 20b022a5c1SBarry Smith /*@C 2166976f2fSJacob Faibussowitsch MatFinalizePackage - This function destroys everything in the Petsc interface to the `Mat` 2266976f2fSJacob Faibussowitsch package. It is called from `PetscFinalize()`. 23b022a5c1SBarry Smith 24b022a5c1SBarry Smith Level: developer 25b022a5c1SBarry Smith 2611a5261eSBarry Smith .seealso: `Mat`, `PetscFinalize()`, `MatInitializePackage()` 27b022a5c1SBarry Smith @*/ 28d71ae5a4SJacob Faibussowitsch PetscErrorCode MatFinalizePackage(void) 29d71ae5a4SJacob Faibussowitsch { 3023bebc0bSBarry Smith MatRootName nnames, names = MatRootNameList; 3101bebe75SBarry Smith 32b022a5c1SBarry Smith PetscFunctionBegin; 339566063dSJacob Faibussowitsch PetscCall(MatSolverTypeDestroy()); 3401bebe75SBarry Smith while (names) { 3501bebe75SBarry Smith nnames = names->next; 369566063dSJacob Faibussowitsch PetscCall(PetscFree(names->rname)); 379566063dSJacob Faibussowitsch PetscCall(PetscFree(names->sname)); 389566063dSJacob Faibussowitsch PetscCall(PetscFree(names->mname)); 399566063dSJacob Faibussowitsch PetscCall(PetscFree(names)); 4001bebe75SBarry Smith names = nnames; 4101bebe75SBarry Smith } 429566063dSJacob Faibussowitsch PetscCall(PetscFunctionListDestroy(&MatList)); 439566063dSJacob Faibussowitsch PetscCall(PetscFunctionListDestroy(&MatOrderingList)); 449566063dSJacob Faibussowitsch PetscCall(PetscFunctionListDestroy(&MatColoringList)); 459566063dSJacob Faibussowitsch PetscCall(PetscFunctionListDestroy(&MatPartitioningList)); 469566063dSJacob Faibussowitsch PetscCall(PetscFunctionListDestroy(&MatCoarsenList)); 4723bebc0bSBarry Smith MatRootNameList = NULL; 48b022a5c1SBarry Smith MatPackageInitialized = PETSC_FALSE; 49b022a5c1SBarry Smith MatRegisterAllCalled = PETSC_FALSE; 50b022a5c1SBarry Smith MatOrderingRegisterAllCalled = PETSC_FALSE; 51b022a5c1SBarry Smith MatColoringRegisterAllCalled = PETSC_FALSE; 52b022a5c1SBarry Smith MatPartitioningRegisterAllCalled = PETSC_FALSE; 53b43b03e9SMark F. Adams MatCoarsenRegisterAllCalled = PETSC_FALSE; 544099cc6bSBarry Smith /* this is not ideal because it exposes SeqAIJ implementation details directly into the base Mat code */ 559566063dSJacob Faibussowitsch PetscCall(PetscFunctionListDestroy(&MatSeqAIJList)); 564099cc6bSBarry Smith MatSeqAIJRegisterAllCalled = PETSC_FALSE; 573ba16761SJacob Faibussowitsch PetscFunctionReturn(PETSC_SUCCESS); 58b022a5c1SBarry Smith } 59e5beb14aSMatthew Knepley 604742e46bSJacob Faibussowitsch #if defined(PETSC_HAVE_CUDA) 614742e46bSJacob Faibussowitsch PETSC_INTERN PetscErrorCode MatSolverTypeRegister_DENSECUDA(void); 624742e46bSJacob Faibussowitsch #endif 634742e46bSJacob Faibussowitsch 644742e46bSJacob Faibussowitsch #if defined(PETSC_HAVE_HIP) 654742e46bSJacob Faibussowitsch PETSC_INTERN PetscErrorCode MatSolverTypeRegister_DENSEHIP(void); 664742e46bSJacob Faibussowitsch #endif 674742e46bSJacob Faibussowitsch 6842c9c57cSBarry Smith #if defined(PETSC_HAVE_MUMPS) 69d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_MUMPS(void); 7042c9c57cSBarry Smith #endif 71fd314934SBarry Smith #if defined(PETSC_HAVE_CUDA) 72d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_CUSPARSE(void); 7342c9c57cSBarry Smith #endif 7447d993e7Ssuyashtn #if defined(PETSC_HAVE_HIP) 75d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_HIPSPARSE(void); 7647d993e7Ssuyashtn #endif 77930e68a5SMark Adams #if defined(PETSC_HAVE_KOKKOS_KERNELS) 78d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_KOKKOS(void); 79930e68a5SMark Adams #endif 8072367587SKarl Rupp #if defined(PETSC_HAVE_VIENNACL) 81d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_ViennaCL(void); 8272367587SKarl Rupp #endif 8342c9c57cSBarry Smith #if defined(PETSC_HAVE_ELEMENTAL) 84d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_Elemental(void); 8542c9c57cSBarry Smith #endif 86d24d4204SJose E. Roman #if defined(PETSC_HAVE_SCALAPACK) 87d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_ScaLAPACK(void); 88d24d4204SJose E. Roman #endif 89d1e78c4fSBarry Smith #if defined(PETSC_HAVE_MATLAB) 90d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_Matlab(void); 9142c9c57cSBarry Smith #endif 921148afceSStefano Zampini #if defined(PETSC_HAVE_ESSL) 93d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_Essl(void); 9442c9c57cSBarry Smith #endif 9542c9c57cSBarry Smith #if defined(PETSC_HAVE_SUPERLU) 96d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_SuperLU(void); 9742c9c57cSBarry Smith #endif 9808f5efcfSPieter Ghysels #if defined(PETSC_HAVE_STRUMPACK) 99d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_STRUMPACK(void); 10008f5efcfSPieter Ghysels #endif 10142c9c57cSBarry Smith #if defined(PETSC_HAVE_PASTIX) 102d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_Pastix(void); 10342c9c57cSBarry Smith #endif 10442c9c57cSBarry Smith #if defined(PETSC_HAVE_SUPERLU_DIST) 105d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_SuperLU_DIST(void); 10642c9c57cSBarry Smith #endif 10742c9c57cSBarry Smith #if defined(PETSC_HAVE_MKL_PARDISO) 108d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_MKL_Pardiso(void); 10942c9c57cSBarry Smith #endif 110d305a81bSVasiliy Kozyrev #if defined(PETSC_HAVE_MKL_CPARDISO) 111d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_MKL_CPardiso(void); 112d305a81bSVasiliy Kozyrev #endif 11342c9c57cSBarry Smith #if defined(PETSC_HAVE_SUITESPARSE) 114d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_SuiteSparse(void); 11542c9c57cSBarry Smith #endif 11642c9c57cSBarry Smith #if defined(PETSC_HAVE_LUSOL) 117d1f0640dSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_Lusol(void); 11842c9c57cSBarry Smith #endif 119*1dd4f53aSPierre Jolivet #if defined(PETSC_HAVE_HTOOL) 120*1dd4f53aSPierre Jolivet PETSC_INTERN PetscErrorCode MatSolverTypeRegister_Htool(void); 121*1dd4f53aSPierre Jolivet #endif 12242c9c57cSBarry Smith 123cc2e6a90SBarry Smith PETSC_INTERN PetscErrorCode MatGetFactor_seqaij_petsc(Mat, MatFactorType, Mat *); 124cc2e6a90SBarry Smith PETSC_INTERN PetscErrorCode MatGetFactor_seqbaij_petsc(Mat, MatFactorType, Mat *); 125cc2e6a90SBarry Smith PETSC_INTERN PetscErrorCode MatGetFactor_seqsbaij_petsc(Mat, MatFactorType, Mat *); 126cc2e6a90SBarry Smith PETSC_INTERN PetscErrorCode MatGetFactor_seqdense_petsc(Mat, MatFactorType, Mat *); 127bfc799aaSStefano Zampini #if defined(PETSC_HAVE_CUDA) 128bfc799aaSStefano Zampini PETSC_INTERN PetscErrorCode MatGetFactor_seqdense_cuda(Mat, MatFactorType, Mat *); 129bfc799aaSStefano Zampini #endif 13047d993e7Ssuyashtn #if defined(PETSC_HAVE_HIP) 13147d993e7Ssuyashtn PETSC_INTERN PetscErrorCode MatGetFactor_seqdense_hip(Mat, MatFactorType, Mat *); 13247d993e7Ssuyashtn #endif 1333423f386SBarry Smith PETSC_INTERN PetscErrorCode MatGetFactor_constantdiagonal_petsc(Mat, MatFactorType, Mat *); 134cc2e6a90SBarry Smith PETSC_INTERN PetscErrorCode MatGetFactor_seqaij_bas(Mat, MatFactorType, Mat *); 13542c9c57cSBarry Smith 1363444e80cSBarry Smith #include <petscbm.h> 1373444e80cSBarry Smith PETSC_INTERN PetscErrorCode PetscBenchCreate_HPL(PetscBench); 1383444e80cSBarry Smith 1391153da11SBarry Smith /*@C 14011a5261eSBarry Smith MatInitializePackage - This function initializes everything in the `Mat` package. It is called 14111a5261eSBarry Smith from `PetscDLLibraryRegister_petscmat()` when using dynamic libraries, and on the first call to `MatCreate()` 1428a690491SBarry Smith when using shared or static libraries. 1431153da11SBarry Smith 1441153da11SBarry Smith Level: developer 1451153da11SBarry Smith 1461cc06b55SBarry Smith .seealso: [](ch_matrices), `Mat`, `PetscInitialize()`, `MatFinalizePackage()` 1471153da11SBarry Smith @*/ 148d71ae5a4SJacob Faibussowitsch PetscErrorCode MatInitializePackage(void) 149d71ae5a4SJacob Faibussowitsch { 1501153da11SBarry Smith char logList[256]; 1518e81d068SLisandro Dalcin PetscBool opt, pkg; 152e94e781bSJacob Faibussowitsch 1531153da11SBarry Smith PetscFunctionBegin; 1543ba16761SJacob Faibussowitsch if (MatPackageInitialized) PetscFunctionReturn(PETSC_SUCCESS); 155b022a5c1SBarry Smith MatPackageInitialized = PETSC_TRUE; 1561755e90bSJacob Faibussowitsch /* Initialize subpackage */ 1579566063dSJacob Faibussowitsch PetscCall(MatMFFDInitializePackage()); 1581153da11SBarry Smith /* Register Classes */ 1599566063dSJacob Faibussowitsch PetscCall(PetscClassIdRegister("Matrix", &MAT_CLASSID)); 1609566063dSJacob Faibussowitsch PetscCall(PetscClassIdRegister("Matrix FD Coloring", &MAT_FDCOLORING_CLASSID)); 1619566063dSJacob Faibussowitsch PetscCall(PetscClassIdRegister("Matrix Coloring", &MAT_COLORING_CLASSID)); 1629566063dSJacob Faibussowitsch PetscCall(PetscClassIdRegister("Matrix MatTranspose Coloring", &MAT_TRANSPOSECOLORING_CLASSID)); 1639566063dSJacob Faibussowitsch PetscCall(PetscClassIdRegister("Matrix Partitioning", &MAT_PARTITIONING_CLASSID)); 1649566063dSJacob Faibussowitsch PetscCall(PetscClassIdRegister("Matrix Coarsen", &MAT_COARSEN_CLASSID)); 1659566063dSJacob Faibussowitsch PetscCall(PetscClassIdRegister("Matrix Null Space", &MAT_NULLSPACE_CLASSID)); 1661153da11SBarry Smith /* Register Constructors */ 1679566063dSJacob Faibussowitsch PetscCall(MatRegisterAll()); 1689566063dSJacob Faibussowitsch PetscCall(MatOrderingRegisterAll()); 1699566063dSJacob Faibussowitsch PetscCall(MatColoringRegisterAll()); 1709566063dSJacob Faibussowitsch PetscCall(MatPartitioningRegisterAll()); 1719566063dSJacob Faibussowitsch PetscCall(MatCoarsenRegisterAll()); 1729566063dSJacob Faibussowitsch PetscCall(MatSeqAIJRegisterAll()); 1731153da11SBarry Smith /* Register Events */ 1749566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMult", MAT_CLASSID, &MAT_Mult)); 1759566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMultAdd", MAT_CLASSID, &MAT_MultAdd)); 1769566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMultTranspose", MAT_CLASSID, &MAT_MultTranspose)); 177c926912cSJose E. Roman PetscCall(PetscLogEventRegister("MatMultHermitian", MAT_CLASSID, &MAT_MultHermitianTranspose)); 1789566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMultTrAdd", MAT_CLASSID, &MAT_MultTransposeAdd)); 179c926912cSJose E. Roman PetscCall(PetscLogEventRegister("MatMultHTAdd", MAT_CLASSID, &MAT_MultHermitianTransposeAdd)); 1809566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSolve", MAT_CLASSID, &MAT_Solve)); 1819566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSolves", MAT_CLASSID, &MAT_Solves)); 1829566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSolveAdd", MAT_CLASSID, &MAT_SolveAdd)); 1839566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSolveTranspos", MAT_CLASSID, &MAT_SolveTranspose)); 1849566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSolveTrAdd", MAT_CLASSID, &MAT_SolveTransposeAdd)); 1859566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSOR", MAT_CLASSID, &MAT_SOR)); 1869566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatForwardSolve", MAT_CLASSID, &MAT_ForwardSolve)); 1879566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatBackwardSolve", MAT_CLASSID, &MAT_BackwardSolve)); 1889566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatLUFactor", MAT_CLASSID, &MAT_LUFactor)); 1899566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatLUFactorSym", MAT_CLASSID, &MAT_LUFactorSymbolic)); 1909566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatLUFactorNum", MAT_CLASSID, &MAT_LUFactorNumeric)); 1919566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatQRFactor", MAT_CLASSID, &MAT_QRFactor)); 1929566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatQRFactorSym", MAT_CLASSID, &MAT_QRFactorSymbolic)); 1939566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatQRFactorNum", MAT_CLASSID, &MAT_QRFactorNumeric)); 1949566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCholeskyFctr", MAT_CLASSID, &MAT_CholeskyFactor)); 1959566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCholFctrSym", MAT_CLASSID, &MAT_CholeskyFactorSymbolic)); 1969566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCholFctrNum", MAT_CLASSID, &MAT_CholeskyFactorNumeric)); 1979566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatFctrFactSchur", MAT_CLASSID, &MAT_FactorFactS)); 1989566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatFctrInvSchur", MAT_CLASSID, &MAT_FactorInvS)); 1999566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatILUFactor", MAT_CLASSID, &MAT_ILUFactor)); 2009566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatILUFactorSym", MAT_CLASSID, &MAT_ILUFactorSymbolic)); 2019566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatICCFactorSym", MAT_CLASSID, &MAT_ICCFactorSymbolic)); 2029566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCopy", MAT_CLASSID, &MAT_Copy)); 2039566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatConvert", MAT_CLASSID, &MAT_Convert)); 2049566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatScale", MAT_CLASSID, &MAT_Scale)); 2059566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatResidual", MAT_CLASSID, &MAT_Residual)); 2069566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatAssemblyBegin", MAT_CLASSID, &MAT_AssemblyBegin)); 2079566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatAssemblyEnd", MAT_CLASSID, &MAT_AssemblyEnd)); 2089566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSetValues", MAT_CLASSID, &MAT_SetValues)); 2099566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatGetValues", MAT_CLASSID, &MAT_GetValues)); 2109566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatGetRow", MAT_CLASSID, &MAT_GetRow)); 2119566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatGetRowIJ", MAT_CLASSID, &MAT_GetRowIJ)); 2129566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCreateSubMats", MAT_CLASSID, &MAT_CreateSubMats)); 2139566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCreateSubMat", MAT_CLASSID, &MAT_CreateSubMat)); 2149566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatGetOrdering", MAT_CLASSID, &MAT_GetOrdering)); 2159566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatIncreaseOvrlp", MAT_CLASSID, &MAT_IncreaseOverlap)); 2169566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatPartitioning", MAT_PARTITIONING_CLASSID, &MAT_Partitioning)); 2179566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatPartitioningND", MAT_PARTITIONING_CLASSID, &MAT_PartitioningND)); 2189566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCoarsen", MAT_COARSEN_CLASSID, &MAT_Coarsen)); 2199566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatZeroEntries", MAT_CLASSID, &MAT_ZeroEntries)); 2209566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatLoad", MAT_CLASSID, &MAT_Load)); 2219566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatView", MAT_CLASSID, &MAT_View)); 2229566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatAXPY", MAT_CLASSID, &MAT_AXPY)); 2239566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatFDColorCreate", MAT_FDCOLORING_CLASSID, &MAT_FDColoringCreate)); 2249566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatFDColorSetUp", MAT_FDCOLORING_CLASSID, &MAT_FDColoringSetUp)); 2259566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatFDColorApply", MAT_FDCOLORING_CLASSID, &MAT_FDColoringApply)); 2269566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatFDColorFunc", MAT_FDCOLORING_CLASSID, &MAT_FDColoringFunction)); 2279566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatTranspose", MAT_CLASSID, &MAT_Transpose)); 2289566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMatSolve", MAT_CLASSID, &MAT_MatSolve)); 2299566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMatTrSolve", MAT_CLASSID, &MAT_MatTrSolve)); 2309566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMatMultSym", MAT_CLASSID, &MAT_MatMultSymbolic)); 2319566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMatMultNum", MAT_CLASSID, &MAT_MatMultNumeric)); 2329566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMatMatMultSym", MAT_CLASSID, &MAT_MatMatMultSymbolic)); 2339566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMatMatMultNum", MAT_CLASSID, &MAT_MatMatMultNumeric)); 2349566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatPtAPSymbolic", MAT_CLASSID, &MAT_PtAPSymbolic)); 2359566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatPtAPNumeric", MAT_CLASSID, &MAT_PtAPNumeric)); 2369566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatRARtSym", MAT_CLASSID, &MAT_RARtSymbolic)); 2379566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatRARtNum", MAT_CLASSID, &MAT_RARtNumeric)); 2389566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMatTrnMultSym", MAT_CLASSID, &MAT_MatTransposeMultSymbolic)); 2399566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMatTrnMultNum", MAT_CLASSID, &MAT_MatTransposeMultNumeric)); 2409566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatTrnMatMultSym", MAT_CLASSID, &MAT_TransposeMatMultSymbolic)); 2419566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatTrnMatMultNum", MAT_CLASSID, &MAT_TransposeMatMultNumeric)); 2429566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatTrnColorCreate", MAT_CLASSID, &MAT_TransposeColoringCreate)); 2439566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatRedundantMat", MAT_CLASSID, &MAT_RedundantMat)); 244fe63dea0SJose E. Roman PetscCall(PetscLogEventRegister("MatGetSeqNZStrct", MAT_CLASSID, &MAT_GetSeqNonzeroStructure)); 2459566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatGetMultiProcB", MAT_CLASSID, &MAT_GetMultiProcBlock)); 2469566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSetRandom", MAT_CLASSID, &MAT_SetRandom)); 2474ebed01fSBarry Smith 2484ebed01fSBarry Smith /* these may be specific to MPIAIJ matrices */ 2499566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMPISumSeqNumeric", MAT_CLASSID, &MAT_Seqstompinum)); 2509566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMPISumSeqSymbolic", MAT_CLASSID, &MAT_Seqstompisym)); 2519566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMPISumSeq", MAT_CLASSID, &MAT_Seqstompi)); 2529566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatMPIConcateSeq", MAT_CLASSID, &MAT_Merge)); 2539566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatGetLocalMat", MAT_CLASSID, &MAT_Getlocalmat)); 2549566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatGetLocalMatCondensed", MAT_CLASSID, &MAT_Getlocalmatcondensed)); 2559566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatGetBrowsOfAcols", MAT_CLASSID, &MAT_GetBrowsOfAcols)); 2569566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatGetBrAoCol", MAT_CLASSID, &MAT_GetBrowsOfAocols)); 2574ebed01fSBarry Smith 2589566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatGetSymTransR", MAT_CLASSID, &MAT_Getsymtransreduced)); 2599566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCUSPARSCopyTo", MAT_CLASSID, &MAT_CUSPARSECopyToGPU)); 2609566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCUSPARSCopyFr", MAT_CLASSID, &MAT_CUSPARSECopyFromGPU)); 2619566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCUSPARSSolAnl", MAT_CLASSID, &MAT_CUSPARSESolveAnalysis)); 2629566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatCUSPARSGenT", MAT_CLASSID, &MAT_CUSPARSEGenerateTranspose)); 26347d993e7Ssuyashtn PetscCall(PetscLogEventRegister("MatHIPSPARSCopyTo", MAT_CLASSID, &MAT_HIPSPARSECopyToGPU)); 26447d993e7Ssuyashtn PetscCall(PetscLogEventRegister("MatHIPSPARSCopyFr", MAT_CLASSID, &MAT_HIPSPARSECopyFromGPU)); 26547d993e7Ssuyashtn PetscCall(PetscLogEventRegister("MatHIPSPARSSolAnl", MAT_CLASSID, &MAT_HIPSPARSESolveAnalysis)); 26647d993e7Ssuyashtn PetscCall(PetscLogEventRegister("MatHIPSPARSGenT", MAT_CLASSID, &MAT_HIPSPARSEGenerateTranspose)); 2679566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatVCLCopyTo", MAT_CLASSID, &MAT_ViennaCLCopyToGPU)); 2689566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatDenseCopyTo", MAT_CLASSID, &MAT_DenseCopyToGPU)); 2699566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatDenseCopyFrom", MAT_CLASSID, &MAT_DenseCopyFromGPU)); 2709566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSetValBatch", MAT_CLASSID, &MAT_SetValuesBatch)); 2713d5bc402SStefano Zampini PetscCall(PetscLogEventRegister("MatCreateGraph", MAT_CLASSID, &MAT_CreateGraph)); 2724ebed01fSBarry Smith 2739566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatColoringApply", MAT_COLORING_CLASSID, &MATCOLORING_Apply)); 2749566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatColoringComm", MAT_COLORING_CLASSID, &MATCOLORING_Comm)); 2759566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatColoringLocal", MAT_COLORING_CLASSID, &MATCOLORING_Local)); 2769566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatColoringIS", MAT_COLORING_CLASSID, &MATCOLORING_ISCreate)); 2779566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatColoringSetUp", MAT_COLORING_CLASSID, &MATCOLORING_SetUp)); 2789566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatColoringWeights", MAT_COLORING_CLASSID, &MATCOLORING_Weights)); 2794f68377dSPeter Brune 2809566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSetPreallCOO", MAT_CLASSID, &MAT_PreallCOO)); 2819566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatSetValuesCOO", MAT_CLASSID, &MAT_SetVCOO)); 282bfcc3627SStefano Zampini 2839566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatH2OpusBuild", MAT_CLASSID, &MAT_H2Opus_Build)); 2849566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatH2OpusComp", MAT_CLASSID, &MAT_H2Opus_Compress)); 2859566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatH2OpusOrth", MAT_CLASSID, &MAT_H2Opus_Orthog)); 2869566063dSJacob Faibussowitsch PetscCall(PetscLogEventRegister("MatH2OpusLR", MAT_CLASSID, &MAT_H2Opus_LR)); 28753022affSStefano Zampini 288217044c2SLisandro Dalcin /* Mark non-collective events */ 2899566063dSJacob Faibussowitsch PetscCall(PetscLogEventSetCollective(MAT_SetValues, PETSC_FALSE)); 2909566063dSJacob Faibussowitsch PetscCall(PetscLogEventSetCollective(MAT_SetValuesBatch, PETSC_FALSE)); 2919566063dSJacob Faibussowitsch PetscCall(PetscLogEventSetCollective(MAT_GetRow, PETSC_FALSE)); 2921153da11SBarry Smith /* Turn off high traffic events by default */ 2939566063dSJacob Faibussowitsch PetscCall(PetscLogEventSetActiveAll(MAT_SetValues, PETSC_FALSE)); 2949566063dSJacob Faibussowitsch PetscCall(PetscLogEventSetActiveAll(MAT_GetValues, PETSC_FALSE)); 2959566063dSJacob Faibussowitsch PetscCall(PetscLogEventSetActiveAll(MAT_GetRow, PETSC_FALSE)); 296e94e781bSJacob Faibussowitsch /* Process Info */ 297e94e781bSJacob Faibussowitsch { 298e94e781bSJacob Faibussowitsch PetscClassId classids[7]; 299217044c2SLisandro Dalcin 300e94e781bSJacob Faibussowitsch classids[0] = MAT_CLASSID; 301e94e781bSJacob Faibussowitsch classids[1] = MAT_FDCOLORING_CLASSID; 302e94e781bSJacob Faibussowitsch classids[2] = MAT_COLORING_CLASSID; 303e94e781bSJacob Faibussowitsch classids[3] = MAT_TRANSPOSECOLORING_CLASSID; 304e94e781bSJacob Faibussowitsch classids[4] = MAT_PARTITIONING_CLASSID; 305e94e781bSJacob Faibussowitsch classids[5] = MAT_COARSEN_CLASSID; 306e94e781bSJacob Faibussowitsch classids[6] = MAT_NULLSPACE_CLASSID; 3079566063dSJacob Faibussowitsch PetscCall(PetscInfoProcessClass("mat", 7, classids)); 3081153da11SBarry Smith } 309217044c2SLisandro Dalcin 3101153da11SBarry Smith /* Process summary exclusions */ 3119566063dSJacob Faibussowitsch PetscCall(PetscOptionsGetString(NULL, NULL, "-log_exclude", logList, sizeof(logList), &opt)); 3121153da11SBarry Smith if (opt) { 3139566063dSJacob Faibussowitsch PetscCall(PetscStrInList("mat", logList, ',', &pkg)); 3149566063dSJacob Faibussowitsch if (pkg) PetscCall(PetscLogEventExcludeClass(MAT_CLASSID)); 3159566063dSJacob Faibussowitsch if (pkg) PetscCall(PetscLogEventExcludeClass(MAT_FDCOLORING_CLASSID)); 3169566063dSJacob Faibussowitsch if (pkg) PetscCall(PetscLogEventExcludeClass(MAT_COLORING_CLASSID)); 3179566063dSJacob Faibussowitsch if (pkg) PetscCall(PetscLogEventExcludeClass(MAT_TRANSPOSECOLORING_CLASSID)); 3189566063dSJacob Faibussowitsch if (pkg) PetscCall(PetscLogEventExcludeClass(MAT_PARTITIONING_CLASSID)); 3199566063dSJacob Faibussowitsch if (pkg) PetscCall(PetscLogEventExcludeClass(MAT_COARSEN_CLASSID)); 3209566063dSJacob Faibussowitsch if (pkg) PetscCall(PetscLogEventExcludeClass(MAT_NULLSPACE_CLASSID)); 3211153da11SBarry Smith } 32242c9c57cSBarry Smith 323c1619fb6SBarry Smith /* Register the PETSc built in factorization based solvers */ 3249566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJ, MAT_FACTOR_LU, MatGetFactor_seqaij_petsc)); 3259566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJ, MAT_FACTOR_CHOLESKY, MatGetFactor_seqaij_petsc)); 3269566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJ, MAT_FACTOR_ILU, MatGetFactor_seqaij_petsc)); 3279566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJ, MAT_FACTOR_ICC, MatGetFactor_seqaij_petsc)); 328c1619fb6SBarry Smith 3299566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJPERM, MAT_FACTOR_LU, MatGetFactor_seqaij_petsc)); 3309566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJPERM, MAT_FACTOR_CHOLESKY, MatGetFactor_seqaij_petsc)); 3319566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJPERM, MAT_FACTOR_ILU, MatGetFactor_seqaij_petsc)); 3329566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJPERM, MAT_FACTOR_ICC, MatGetFactor_seqaij_petsc)); 333c1619fb6SBarry Smith 3349566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATCONSTANTDIAGONAL, MAT_FACTOR_LU, MatGetFactor_constantdiagonal_petsc)); 3359566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATCONSTANTDIAGONAL, MAT_FACTOR_CHOLESKY, MatGetFactor_constantdiagonal_petsc)); 3369566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATCONSTANTDIAGONAL, MAT_FACTOR_ILU, MatGetFactor_constantdiagonal_petsc)); 3379566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATCONSTANTDIAGONAL, MAT_FACTOR_ICC, MatGetFactor_constantdiagonal_petsc)); 3383423f386SBarry Smith 3399779e05dSSatish Balay #if defined(PETSC_HAVE_MKL_SPARSE) 3409566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJMKL, MAT_FACTOR_LU, MatGetFactor_seqaij_petsc)); 3419566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJMKL, MAT_FACTOR_CHOLESKY, MatGetFactor_seqaij_petsc)); 3429566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJMKL, MAT_FACTOR_ILU, MatGetFactor_seqaij_petsc)); 3439566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJMKL, MAT_FACTOR_ICC, MatGetFactor_seqaij_petsc)); 344b5b72c8aSIrina Sokolova 3459566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQBAIJMKL, MAT_FACTOR_LU, MatGetFactor_seqbaij_petsc)); 3469566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQBAIJMKL, MAT_FACTOR_CHOLESKY, MatGetFactor_seqbaij_petsc)); 3479566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQBAIJMKL, MAT_FACTOR_ILU, MatGetFactor_seqbaij_petsc)); 3489566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQBAIJMKL, MAT_FACTOR_ICC, MatGetFactor_seqbaij_petsc)); 349191b95cbSRichard Tran Mills #endif 3502251f9d6SRichard Tran Mills /* Above, we register the PETSc built-in factorization solvers for MATSEQAIJMKL. In the future, we may want to use 3512251f9d6SRichard Tran Mills * some of the MKL-provided ones instead. */ 3522251f9d6SRichard Tran Mills 3539566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJCRL, MAT_FACTOR_LU, MatGetFactor_seqaij_petsc)); 3549566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJCRL, MAT_FACTOR_CHOLESKY, MatGetFactor_seqaij_petsc)); 3559566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJCRL, MAT_FACTOR_ILU, MatGetFactor_seqaij_petsc)); 3569566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQAIJCRL, MAT_FACTOR_ICC, MatGetFactor_seqaij_petsc)); 357c1619fb6SBarry Smith 3589566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQBAIJ, MAT_FACTOR_LU, MatGetFactor_seqbaij_petsc)); 3599566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQBAIJ, MAT_FACTOR_CHOLESKY, MatGetFactor_seqbaij_petsc)); 3609566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQBAIJ, MAT_FACTOR_ILU, MatGetFactor_seqbaij_petsc)); 3619566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQBAIJ, MAT_FACTOR_ICC, MatGetFactor_seqbaij_petsc)); 362c1619fb6SBarry Smith 3639566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQSBAIJ, MAT_FACTOR_CHOLESKY, MatGetFactor_seqsbaij_petsc)); 3649566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQSBAIJ, MAT_FACTOR_ICC, MatGetFactor_seqsbaij_petsc)); 365c1619fb6SBarry Smith 3669566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQDENSE, MAT_FACTOR_LU, MatGetFactor_seqdense_petsc)); 3679566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQDENSE, MAT_FACTOR_ILU, MatGetFactor_seqdense_petsc)); 3689566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQDENSE, MAT_FACTOR_CHOLESKY, MatGetFactor_seqdense_petsc)); 3699566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERPETSC, MATSEQDENSE, MAT_FACTOR_QR, MatGetFactor_seqdense_petsc)); 370bfc799aaSStefano Zampini #if defined(PETSC_HAVE_CUDA) 3714742e46bSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_DENSECUDA()); 372bfc799aaSStefano Zampini #endif 37347d993e7Ssuyashtn #if defined(PETSC_HAVE_HIP) 3744742e46bSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_DENSEHIP()); 37547d993e7Ssuyashtn #endif 376c1619fb6SBarry Smith 3779566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister(MATSOLVERBAS, MATSEQAIJ, MAT_FACTOR_ICC, MatGetFactor_seqaij_bas)); 378c1619fb6SBarry Smith 37942c9c57cSBarry Smith /* 38042c9c57cSBarry Smith Register the external package factorization based solvers 38142c9c57cSBarry Smith Eventually we don't want to have these hardwired here at compile time of PETSc 38242c9c57cSBarry Smith */ 38342c9c57cSBarry Smith #if defined(PETSC_HAVE_MUMPS) 3849566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_MUMPS()); 38542c9c57cSBarry Smith #endif 386fd314934SBarry Smith #if defined(PETSC_HAVE_CUDA) 3879566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_CUSPARSE()); 38842c9c57cSBarry Smith #endif 38947d993e7Ssuyashtn #if defined(PETSC_HAVE_HIP) 39047d993e7Ssuyashtn PetscCall(MatSolverTypeRegister_HIPSPARSE()); 39147d993e7Ssuyashtn #endif 392930e68a5SMark Adams #if defined(PETSC_HAVE_KOKKOS_KERNELS) 3939566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_KOKKOS()); 394930e68a5SMark Adams #endif 39572367587SKarl Rupp #if defined(PETSC_HAVE_VIENNACL) 3969566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_ViennaCL()); 39772367587SKarl Rupp #endif 39842c9c57cSBarry Smith #if defined(PETSC_HAVE_ELEMENTAL) 3999566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_Elemental()); 40042c9c57cSBarry Smith #endif 401d24d4204SJose E. Roman #if defined(PETSC_HAVE_SCALAPACK) 4029566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_ScaLAPACK()); 403d24d4204SJose E. Roman #endif 404d1e78c4fSBarry Smith #if defined(PETSC_HAVE_MATLAB) 4059566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_Matlab()); 40642c9c57cSBarry Smith #endif 4071148afceSStefano Zampini #if defined(PETSC_HAVE_ESSL) 4089566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_Essl()); 40942c9c57cSBarry Smith #endif 41042c9c57cSBarry Smith #if defined(PETSC_HAVE_SUPERLU) 4119566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_SuperLU()); 41242c9c57cSBarry Smith #endif 41308f5efcfSPieter Ghysels #if defined(PETSC_HAVE_STRUMPACK) 4149566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_STRUMPACK()); 41508f5efcfSPieter Ghysels #endif 41642c9c57cSBarry Smith #if defined(PETSC_HAVE_PASTIX) 4179566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_Pastix()); 41842c9c57cSBarry Smith #endif 41942c9c57cSBarry Smith #if defined(PETSC_HAVE_SUPERLU_DIST) 4209566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_SuperLU_DIST()); 42142c9c57cSBarry Smith #endif 42242c9c57cSBarry Smith #if defined(PETSC_HAVE_MKL_PARDISO) 4239566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_MKL_Pardiso()); 42442c9c57cSBarry Smith #endif 425d305a81bSVasiliy Kozyrev #if defined(PETSC_HAVE_MKL_CPARDISO) 4269566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_MKL_CPardiso()); 427d305a81bSVasiliy Kozyrev #endif 42842c9c57cSBarry Smith #if defined(PETSC_HAVE_SUITESPARSE) 4299566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_SuiteSparse()); 43042c9c57cSBarry Smith #endif 43142c9c57cSBarry Smith #if defined(PETSC_HAVE_LUSOL) 4329566063dSJacob Faibussowitsch PetscCall(MatSolverTypeRegister_Lusol()); 43342c9c57cSBarry Smith #endif 434*1dd4f53aSPierre Jolivet #if defined(PETSC_HAVE_HTOOL) 435*1dd4f53aSPierre Jolivet PetscCall(MatSolverTypeRegister_Htool()); 436*1dd4f53aSPierre Jolivet #endif 4373444e80cSBarry Smith #if defined(PETSC_HAVE_HPL) 4383444e80cSBarry Smith PetscCall(PetscBenchRegister(PETSCBMHPL, PetscBenchCreate_HPL)); 4393444e80cSBarry Smith #endif 4408e81d068SLisandro Dalcin /* Register package finalizer */ 4419566063dSJacob Faibussowitsch PetscCall(PetscRegisterFinalize(MatFinalizePackage)); 4423ba16761SJacob Faibussowitsch PetscFunctionReturn(PETSC_SUCCESS); 4431153da11SBarry Smith } 4441153da11SBarry Smith 445aa2d57e9SJed Brown #if defined(PETSC_HAVE_DYNAMIC_LIBRARIES) 4461153da11SBarry Smith /* 4471153da11SBarry Smith PetscDLLibraryRegister - This function is called when the dynamic library it is in is opened. 4481153da11SBarry Smith 4493f92711fSBarry Smith This one registers all the matrix methods that are in the basic PETSc Matrix library. 4501153da11SBarry Smith 4511153da11SBarry Smith */ 452d71ae5a4SJacob Faibussowitsch PETSC_EXTERN PetscErrorCode PetscDLLibraryRegister_petscmat(void) 453d71ae5a4SJacob Faibussowitsch { 4541153da11SBarry Smith PetscFunctionBegin; 4559566063dSJacob Faibussowitsch PetscCall(MatInitializePackage()); 4563ba16761SJacob Faibussowitsch PetscFunctionReturn(PETSC_SUCCESS); 4571153da11SBarry Smith } 4581153da11SBarry Smith 459aa2d57e9SJed Brown #endif /* PETSC_HAVE_DYNAMIC_LIBRARIES */ 460