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