1 #define PETSCKSP_DLL 2 3 #include "private/pcimpl.h" /*I "petscpc.h" I*/ 4 5 EXTERN_C_BEGIN 6 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_Jacobi(PC); 7 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_BJacobi(PC); 8 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_PBJacobi(PC); 9 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_ILU(PC); 10 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_None(PC); 11 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_LU(PC); 12 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_SOR(PC); 13 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_Shell(PC); 14 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_MG(PC); 15 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_Eisenstat(PC); 16 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_ICC(PC); 17 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_ASM(PC); 18 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_KSP(PC); 19 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_Composite(PC); 20 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_Redundant(PC); 21 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_NN(PC); 22 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_Cholesky(PC); 23 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_FieldSplit(PC); 24 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_Galerkin(PC); 25 #if defined(PETSC_HAVE_ML) 26 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_ML(PC); 27 #endif 28 #if defined(PETSC_HAVE_SPAI) 29 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_SPAI(PC); 30 #endif 31 #if defined(PETSC_HAVE_SAMG) 32 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_SAMG(PC); 33 #endif 34 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_Mat(PC); 35 #if defined(PETSC_HAVE_HYPRE) 36 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_HYPRE(PC); 37 #endif 38 #if !defined(PETSC_USE_64BIT_INDICES) && !defined(PETSC_USE_COMPLEX) && !defined(PETSC_USE_SINGLE) && !defined(PETSC_USE_MAT_SINGLE) && !defined(PETSC_USE_LONG_DOUBLE) && !defined(PETSC_USE_INT) 39 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_TFS(PC); 40 #endif 41 #if defined(PETSC_HAVE_PROMETHEUS) 42 EXTERN PetscErrorCode PETSCKSP_DLLEXPORT PCCreate_Prometheus(PC); 43 #endif 44 45 46 EXTERN_C_END 47 48 #undef __FUNCT__ 49 #define __FUNCT__ "PCRegisterAll" 50 /*@C 51 PCRegisterAll - Registers all of the preconditioners in the PC package. 52 53 Not Collective 54 55 Input Parameter: 56 . path - the library where the routines are to be found (optional) 57 58 Level: advanced 59 60 .keywords: PC, register, all 61 62 .seealso: PCRegisterDynamic(), PCRegisterDestroy() 63 @*/ 64 PetscErrorCode PETSCKSP_DLLEXPORT PCRegisterAll(const char path[]) 65 { 66 PetscErrorCode ierr; 67 68 PetscFunctionBegin; 69 PCRegisterAllCalled = PETSC_TRUE; 70 71 ierr = PCRegisterDynamic(PCNONE ,path,"PCCreate_None",PCCreate_None);CHKERRQ(ierr); 72 ierr = PCRegisterDynamic(PCJACOBI ,path,"PCCreate_Jacobi",PCCreate_Jacobi);CHKERRQ(ierr); 73 ierr = PCRegisterDynamic(PCPBJACOBI ,path,"PCCreate_PBJacobi",PCCreate_PBJacobi);CHKERRQ(ierr); 74 ierr = PCRegisterDynamic(PCBJACOBI ,path,"PCCreate_BJacobi",PCCreate_BJacobi);CHKERRQ(ierr); 75 ierr = PCRegisterDynamic(PCSOR ,path,"PCCreate_SOR",PCCreate_SOR);CHKERRQ(ierr); 76 ierr = PCRegisterDynamic(PCLU ,path,"PCCreate_LU",PCCreate_LU);CHKERRQ(ierr); 77 ierr = PCRegisterDynamic(PCSHELL ,path,"PCCreate_Shell",PCCreate_Shell);CHKERRQ(ierr); 78 ierr = PCRegisterDynamic(PCMG ,path,"PCCreate_MG",PCCreate_MG);CHKERRQ(ierr); 79 ierr = PCRegisterDynamic(PCEISENSTAT ,path,"PCCreate_Eisenstat",PCCreate_Eisenstat);CHKERRQ(ierr); 80 ierr = PCRegisterDynamic(PCILU ,path,"PCCreate_ILU",PCCreate_ILU);CHKERRQ(ierr); 81 ierr = PCRegisterDynamic(PCICC ,path,"PCCreate_ICC",PCCreate_ICC);CHKERRQ(ierr); 82 ierr = PCRegisterDynamic(PCCHOLESKY ,path,"PCCreate_Cholesky",PCCreate_Cholesky);CHKERRQ(ierr); 83 ierr = PCRegisterDynamic(PCASM ,path,"PCCreate_ASM",PCCreate_ASM);CHKERRQ(ierr); 84 ierr = PCRegisterDynamic(PCKSP ,path,"PCCreate_KSP",PCCreate_KSP);CHKERRQ(ierr); 85 ierr = PCRegisterDynamic(PCCOMPOSITE ,path,"PCCreate_Composite",PCCreate_Composite);CHKERRQ(ierr); 86 ierr = PCRegisterDynamic(PCREDUNDANT ,path,"PCCreate_Redundant",PCCreate_Redundant);CHKERRQ(ierr); 87 ierr = PCRegisterDynamic(PCNN ,path,"PCCreate_NN",PCCreate_NN);CHKERRQ(ierr); 88 ierr = PCRegisterDynamic(PCMAT ,path,"PCCreate_Mat",PCCreate_Mat);CHKERRQ(ierr); 89 ierr = PCRegisterDynamic(PCFIELDSPLIT ,path,"PCCreate_FieldSplit",PCCreate_FieldSplit);CHKERRQ(ierr); 90 ierr = PCRegisterDynamic(PCFIELDSPLIT ,path,"PCCreate_Galerkin",PCCreate_Galerkin);CHKERRQ(ierr); 91 #if defined(PETSC_HAVE_ML) 92 ierr = PCRegisterDynamic(PCML ,path,"PCCreate_ML",PCCreate_ML);CHKERRQ(ierr); 93 #endif 94 #if defined(PETSC_HAVE_SPAI) 95 ierr = PCRegisterDynamic(PCSPAI ,path,"PCCreate_SPAI",PCCreate_SPAI);CHKERRQ(ierr); 96 #endif 97 #if defined(PETSC_HAVE_SAMG) 98 ierr = PCRegisterDynamic(PCSAMG ,path,"PCCreate_SAMG",PCCreate_SAMG);CHKERRQ(ierr); 99 #endif 100 #if defined(PETSC_HAVE_HYPRE) 101 ierr = PCRegisterDynamic(PCHYPRE ,path,"PCCreate_HYPRE",PCCreate_HYPRE);CHKERRQ(ierr); 102 #endif 103 #if !defined(PETSC_USE_64BIT_INDICES) && !defined(PETSC_USE_COMPLEX) && !defined(PETSC_USE_SINGLE) && !defined(PETSC_USE_MAT_SINGLE) && !defined(PETSC_USE_LONG_DOUBLE) && !defined(PETSC_USE_INT) 104 ierr = PCRegisterDynamic(PCTFS ,path,"PCCreate_TFS",PCCreate_TFS);CHKERRQ(ierr); 105 #endif 106 #if defined(PETSC_HAVE_PROMETHEUS) 107 ierr = PCRegisterDynamic(PCPROMETHEUS ,path,"PCCreate_Prometheus",PCCreate_Prometheus);CHKERRQ(ierr); 108 #endif 109 110 PetscFunctionReturn(0); 111 } 112