1d03aef70SBarry Smith /* 237f753daSBarry Smith Preconditioner module. 3d03aef70SBarry Smith */ 46524c165SJacob Faibussowitsch #ifndef PETSCPC_H 526bd1501SBarry Smith #define PETSCPC_H 6ac09b921SBarry Smith 71e25c274SJed Brown #include <petscmat.h> 877a3c058SKarl Rupp #include <petscdmtypes.h> 9b0753f9dSMatthew G. Knepley #include <petscpctypes.h> 10d03aef70SBarry Smith 11ac09b921SBarry Smith /* SUBMANSEC = PC */ 12ac09b921SBarry Smith 13607a6623SBarry Smith PETSC_EXTERN PetscErrorCode PCInitializePackage(void); 141dbb0a54SBarry Smith 15eec0b4cfSBarry Smith /* 16eec0b4cfSBarry Smith PCList contains the list of preconditioners currently registered 17bdf89e91SBarry Smith These are added with PCRegister() 18eec0b4cfSBarry Smith */ 19140e18c1SBarry Smith PETSC_EXTERN PetscFunctionList PCList; 2082bf6240SBarry Smith 21123ea438SMatthew Knepley /* Logging support */ 22014dd563SJed Brown PETSC_EXTERN PetscClassId PC_CLASSID; 23123ea438SMatthew Knepley 249d8081ecSMatthew G. Knepley /* Arrays of names for options in implementation PCs */ 259d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const *const PCSides; 269d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCJacobiTypes[]; 279d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCASMTypes[]; 289d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCGASMTypes[]; 299d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCCompositeTypes[]; 309d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCFieldSplitSchurPreTypes[]; 319d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCFieldSplitSchurFactTypes[]; 329d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCPARMSGlobalTypes[]; 339d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCPARMSLocalTypes[]; 349d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCMGTypes[]; 359d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCMGCycleTypes[]; 369d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCMGGalerkinTypes[]; 37557cf195SMatthew G. Knepley PETSC_EXTERN const char *const PCMGCoarseSpaceTypes[]; 389d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCExoticTypes[]; 399d8081ecSMatthew G. Knepley PETSC_EXTERN const char *const PCPatchConstructTypes[]; 4037eeb815SJakub Kruzik PETSC_EXTERN const char *const PCDeflationTypes[]; 411b2b9847SBarry Smith PETSC_EXTERN const char *const *const PCFailedReasons; 429d8081ecSMatthew G. Knepley 43014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCCreate(MPI_Comm, PC *); 4419fd82e9SBarry Smith PETSC_EXTERN PetscErrorCode PCSetType(PC, PCType); 45c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCGetType(PC, PCType *); 46014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSetUp(PC); 471b2b9847SBarry Smith 481b2b9847SBarry Smith PETSC_EXTERN PetscErrorCode PCSetFailedReason(PC, PCFailedReason); 49c0decd05SBarry Smith PETSC_EXTERN PetscErrorCode PCGetFailedReason(PC, PCFailedReason *); 50d71ae5a4SJacob Faibussowitsch PETSC_DEPRECATED_FUNCTION("Use PCGetFailedReason() (since version 3.11)") static inline PetscErrorCode PCGetSetUpFailedReason(PC pc, PCFailedReason *reason) 51d71ae5a4SJacob Faibussowitsch { 529371c9d4SSatish Balay return PCGetFailedReason(pc, reason); 539371c9d4SSatish Balay } 541b2b9847SBarry Smith PETSC_EXTERN PetscErrorCode PCGetFailedReasonRank(PC, PCFailedReason *); 551b2b9847SBarry Smith 56014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSetUpOnBlocks(PC); 57014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCApply(PC, Vec, Vec); 58c677e75fSPierre Jolivet PETSC_EXTERN PetscErrorCode PCMatApply(PC, Mat, Mat); 59014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCApplySymmetricLeft(PC, Vec, Vec); 60014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCApplySymmetricRight(PC, Vec, Vec); 61014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCApplyBAorAB(PC, PCSide, Vec, Vec, Vec); 62014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCApplyTranspose(PC, Vec, Vec); 63014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCApplyTransposeExists(PC, PetscBool *); 64014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCApplyBAorABTranspose(PC, PCSide, Vec, Vec, Vec); 6523ee1639SBarry Smith PETSC_EXTERN PetscErrorCode PCSetReusePreconditioner(PC, PetscBool); 66c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCGetReusePreconditioner(PC, PetscBool *); 67422a814eSBarry Smith PETSC_EXTERN PetscErrorCode PCSetErrorIfFailure(PC, PetscBool); 684d0a8057SBarry Smith 6955849f57SBarry Smith #define PC_FILE_CLASSID 1211222 7055849f57SBarry Smith 71014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCApplyRichardson(PC, Vec, Vec, Vec, PetscReal, PetscReal, PetscReal, PetscInt, PetscBool, PetscInt *, PCRichardsonConvergedReason *); 72014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCApplyRichardsonExists(PC, PetscBool *); 7349517cdeSBarry Smith PETSC_EXTERN PetscErrorCode PCSetUseAmat(PC, PetscBool); 7449517cdeSBarry Smith PETSC_EXTERN PetscErrorCode PCGetUseAmat(PC, PetscBool *); 7584cb2905SBarry Smith 76bdf89e91SBarry Smith PETSC_EXTERN PetscErrorCode PCRegister(const char[], PetscErrorCode (*)(PC)); 7730de9b25SBarry Smith 78014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCReset(PC); 79014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCDestroy(PC *); 80014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSetFromOptions(PC); 8114c91fddSBarry Smith 82014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorGetMatrix(PC, Mat *); 83014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSetModifySubMatrices(PC, PetscErrorCode (*)(PC, PetscInt, const IS[], const IS[], Mat[], void *), void *); 84014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCModifySubMatrices(PC, PetscInt, const IS[], const IS[], Mat[], void *); 855b116368SBarry Smith 8623ee1639SBarry Smith PETSC_EXTERN PetscErrorCode PCSetOperators(PC, Mat, Mat); 8723ee1639SBarry Smith PETSC_EXTERN PetscErrorCode PCGetOperators(PC, Mat *, Mat *); 88014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGetOperatorsSet(PC, PetscBool *, PetscBool *); 894b0e389bSBarry Smith 90014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCView(PC, PetscViewer); 9155849f57SBarry Smith PETSC_EXTERN PetscErrorCode PCLoad(PC, PetscViewer); 92fe2efc57SMark PETSC_EXTERN PetscErrorCode PCViewFromOptions(PC, PetscObject, const char[]); 937bc3d0afSSatish Balay 94014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSetOptionsPrefix(PC, const char[]); 95014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCAppendOptionsPrefix(PC, const char[]); 96014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGetOptionsPrefix(PC, const char *[]); 978ed539a5SBarry Smith 980bacdadaSStefano Zampini PETSC_EXTERN PetscErrorCode PCComputeOperator(PC, MatType, Mat *); 99d71ae5a4SJacob Faibussowitsch PETSC_DEPRECATED_FUNCTION("Use PCComputeOperator() (since version 3.12)") static inline PetscErrorCode PCComputeExplicitOperator(PC A, Mat *B) 100d71ae5a4SJacob Faibussowitsch { 101*f22e26b7SPierre Jolivet return PCComputeOperator(A, PETSC_NULLPTR, B); 1029371c9d4SSatish Balay } 10371601f6fSBarry Smith 104d6913704SBarry Smith /* 105d6913704SBarry Smith These are used to provide extra scaling of preconditioned 1060f3b3ca1SHong Zhang operator for time-stepping schemes like in SUNDIALS 107d6913704SBarry Smith */ 108014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGetDiagonalScale(PC, PetscBool *); 109014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCDiagonalScaleLeft(PC, Vec, Vec); 110014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCDiagonalScaleRight(PC, Vec, Vec); 111014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSetDiagonalScale(PC, Vec); 112d6913704SBarry Smith 113f02e8f50SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCSetDM(PC, DM); 114f02e8f50SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCGetDM(PC, DM *); 115f02e8f50SMatthew G. Knepley 116fd2dd295SFande Kong PETSC_EXTERN PetscErrorCode PCGetInterpolations(PC, PetscInt *, Mat *[]); 117fd2dd295SFande Kong PETSC_EXTERN PetscErrorCode PCGetCoarseOperators(PC pc, PetscInt *, Mat *[]); 118fd2dd295SFande Kong 119f02e8f50SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCSetCoordinates(PC, PetscInt, PetscInt, PetscReal *); 120f02e8f50SMatthew G. Knepley 121f02e8f50SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCSetApplicationContext(PC, void *); 122f02e8f50SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCGetApplicationContext(PC, void *); 123f02e8f50SMatthew G. Knepley 12484cb2905SBarry Smith /* ------------- options specific to particular preconditioners --------- */ 125329f5518SBarry Smith 126baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCJacobiSetType(PC, PCJacobiType); 127baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCJacobiGetType(PC, PCJacobiType *); 128baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCJacobiSetUseAbs(PC, PetscBool); 129baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCJacobiGetUseAbs(PC, PetscBool *); 13067ed0f3bSStefano Zampini PETSC_EXTERN PetscErrorCode PCJacobiSetFixDiagonal(PC, PetscBool); 13167ed0f3bSStefano Zampini PETSC_EXTERN PetscErrorCode PCJacobiGetFixDiagonal(PC, PetscBool *); 132014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSORSetSymmetric(PC, MatSORType); 133c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCSORGetSymmetric(PC, MatSORType *); 134014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSORSetOmega(PC, PetscReal); 135c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCSORGetOmega(PC, PetscReal *); 136014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSORSetIterations(PC, PetscInt, PetscInt); 137c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCSORGetIterations(PC, PetscInt *, PetscInt *); 138d03aef70SBarry Smith 139014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCEisenstatSetOmega(PC, PetscReal); 140c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCEisenstatGetOmega(PC, PetscReal *); 141c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCEisenstatSetNoDiagonalScaling(PC, PetscBool); 142c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCEisenstatGetNoDiagonalScaling(PC, PetscBool *); 143421c37bdSBarry Smith 144014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCBJacobiSetTotalBlocks(PC, PetscInt, const PetscInt[]); 145c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCBJacobiGetTotalBlocks(PC, PetscInt *, const PetscInt *[]); 146014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCBJacobiSetLocalBlocks(PC, PetscInt, const PetscInt[]); 147c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCBJacobiGetLocalBlocks(PC, PetscInt *, const PetscInt *[]); 1481eb62cbbSBarry Smith 149014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCShellSetApply(PC, PetscErrorCode (*)(PC, Vec, Vec)); 1507b6e2003SPierre Jolivet PETSC_EXTERN PetscErrorCode PCShellSetMatApply(PC, PetscErrorCode (*)(PC, Mat, Mat)); 1511b581b66SBarry Smith PETSC_EXTERN PetscErrorCode PCShellSetApplySymmetricLeft(PC, PetscErrorCode (*)(PC, Vec, Vec)); 1521b581b66SBarry Smith PETSC_EXTERN PetscErrorCode PCShellSetApplySymmetricRight(PC, PetscErrorCode (*)(PC, Vec, Vec)); 153014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCShellSetApplyBA(PC, PetscErrorCode (*)(PC, PCSide, Vec, Vec, Vec)); 154014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCShellSetApplyTranspose(PC, PetscErrorCode (*)(PC, Vec, Vec)); 155014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCShellSetSetUp(PC, PetscErrorCode (*)(PC)); 156014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCShellSetApplyRichardson(PC, PetscErrorCode (*)(PC, Vec, Vec, Vec, PetscReal, PetscReal, PetscReal, PetscInt, PetscBool, PetscInt *, PCRichardsonConvergedReason *)); 157014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCShellSetView(PC, PetscErrorCode (*)(PC, PetscViewer)); 158014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCShellSetDestroy(PC, PetscErrorCode (*)(PC)); 159014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCShellSetContext(PC, void *); 1603ec1f749SStefano Zampini PETSC_EXTERN PetscErrorCode PCShellGetContext(PC, void *); 161014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCShellSetName(PC, const char[]); 162014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCShellGetName(PC, const char *[]); 163aabeff55SBarry Smith 164014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorSetZeroPivot(PC, PetscReal); 165d90ac83dSHong Zhang 166014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorSetShiftType(PC, MatFactorShiftType); 167014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorSetShiftAmount(PC, PetscReal); 168d90ac83dSHong Zhang 169ea799195SBarry Smith PETSC_EXTERN PetscErrorCode PCFactorSetMatSolverType(PC, MatSolverType); 170ea799195SBarry Smith PETSC_EXTERN PetscErrorCode PCFactorGetMatSolverType(PC, MatSolverType *); 1713ca39a21SBarry Smith PETSC_EXTERN PetscErrorCode PCFactorSetUpMatSolverType(PC); 172d71ae5a4SJacob Faibussowitsch PETSC_DEPRECATED_FUNCTION("Use PCFactorSetMatSolverType() (since version 3.9)") static inline PetscErrorCode PCFactorSetMatSolverPackage(PC pc, MatSolverType stype) 173d71ae5a4SJacob Faibussowitsch { 1749371c9d4SSatish Balay return PCFactorSetMatSolverType(pc, stype); 1759371c9d4SSatish Balay } 176d71ae5a4SJacob Faibussowitsch PETSC_DEPRECATED_FUNCTION("Use PCFactorGetMatSolverType() (since version 3.9)") static inline PetscErrorCode PCFactorGetMatSolverPackage(PC pc, MatSolverType *stype) 177d71ae5a4SJacob Faibussowitsch { 1789371c9d4SSatish Balay return PCFactorGetMatSolverType(pc, stype); 1799371c9d4SSatish Balay } 180d71ae5a4SJacob Faibussowitsch PETSC_DEPRECATED_FUNCTION("Use PCFactorSetUpMatSolverType() (since version 3.9)") static inline PetscErrorCode PCFactorSetUpMatSolverPackage(PC pc) 181d71ae5a4SJacob Faibussowitsch { 1829371c9d4SSatish Balay return PCFactorSetUpMatSolverType(pc); 1839371c9d4SSatish Balay } 1842401956bSBarry Smith 185014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorSetFill(PC, PetscReal); 186014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorSetColumnPivot(PC, PetscReal); 187014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorReorderForNonzeroDiagonal(PC, PetscReal); 188421c37bdSBarry Smith 18919fd82e9SBarry Smith PETSC_EXTERN PetscErrorCode PCFactorSetMatOrderingType(PC, MatOrderingType); 190014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorSetReuseOrdering(PC, PetscBool); 191014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorSetReuseFill(PC, PetscBool); 1928e37d05fSBarry Smith PETSC_EXTERN PetscErrorCode PCFactorSetUseInPlace(PC, PetscBool); 1938e37d05fSBarry Smith PETSC_EXTERN PetscErrorCode PCFactorGetUseInPlace(PC, PetscBool *); 19492e9c092SBarry Smith PETSC_EXTERN PetscErrorCode PCFactorSetAllowDiagonalFill(PC, PetscBool); 19592e9c092SBarry Smith PETSC_EXTERN PetscErrorCode PCFactorGetAllowDiagonalFill(PC, PetscBool *); 196014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorSetPivotInBlocks(PC, PetscBool); 197f5a88c2aSLois Curfman McInnes 198014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorSetLevels(PC, PetscInt); 199c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCFactorGetLevels(PC, PetscInt *); 200014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFactorSetDropTolerance(PC, PetscReal, PetscReal, PetscInt); 201c7f610a1SBarry Smith PETSC_EXTERN PetscErrorCode PCFactorGetZeroPivot(PC, PetscReal *); 202c7f610a1SBarry Smith PETSC_EXTERN PetscErrorCode PCFactorGetShiftAmount(PC, PetscReal *); 203c7f610a1SBarry Smith PETSC_EXTERN PetscErrorCode PCFactorGetShiftType(PC, MatFactorShiftType *); 204b35a507dSBarry Smith 205014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCASMSetLocalSubdomains(PC, PetscInt, IS[], IS[]); 206014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCASMSetTotalSubdomains(PC, PetscInt, IS[], IS[]); 207014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCASMSetOverlap(PC, PetscInt); 208d709ea83SDmitry Karpeev PETSC_EXTERN PetscErrorCode PCASMSetDMSubdomains(PC, PetscBool); 209d709ea83SDmitry Karpeev PETSC_EXTERN PetscErrorCode PCASMGetDMSubdomains(PC, PetscBool *); 210014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCASMSetSortIndices(PC, PetscBool); 211f746d493SDmitry Karpeev 212014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCASMSetType(PC, PCASMType); 213c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCASMGetType(PC, PCASMType *); 21412cd4985SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCASMSetLocalType(PC, PCCompositeType); 21512cd4985SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCASMGetLocalType(PC, PCCompositeType *); 216014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCASMCreateSubdomains(Mat, PetscInt, IS *[]); 217014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCASMDestroySubdomains(PetscInt, IS[], IS[]); 218014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCASMCreateSubdomains2D(PetscInt, PetscInt, PetscInt, PetscInt, PetscInt, PetscInt, PetscInt *, IS **, IS **); 219014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCASMGetLocalSubdomains(PC, PetscInt *, IS *[], IS *[]); 220014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCASMGetLocalSubmatrices(PC, PetscInt *, Mat *[]); 22180ec0b7dSPatrick Sanan PETSC_EXTERN PetscErrorCode PCASMGetSubMatType(PC, MatType *); 22280ec0b7dSPatrick Sanan PETSC_EXTERN PetscErrorCode PCASMSetSubMatType(PC, MatType); 223981c4779SBarry Smith 2248f3b4b4dSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCGASMSetTotalSubdomains(PC, PetscInt); 225014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGASMSetSubdomains(PC, PetscInt, IS[], IS[]); 226014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGASMSetOverlap(PC, PetscInt); 2278f3b4b4dSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCGASMSetUseDMSubdomains(PC, PetscBool); 2288f3b4b4dSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCGASMGetUseDMSubdomains(PC, PetscBool *); 229014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGASMSetSortIndices(PC, PetscBool); 230f746d493SDmitry Karpeev 231014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGASMSetType(PC, PCGASMType); 2328f3b4b4dSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCGASMCreateSubdomains(Mat, PetscInt, PetscInt *, IS *[]); 2332c112581SDmitry Karpeev PETSC_EXTERN PetscErrorCode PCGASMDestroySubdomains(PetscInt, IS *[], IS *[]); 234014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGASMCreateSubdomains2D(PC, PetscInt, PetscInt, PetscInt, PetscInt, PetscInt, PetscInt, PetscInt *, IS **, IS **); 235014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGASMGetSubdomains(PC, PetscInt *, IS *[], IS *[]); 236014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGASMGetSubmatrices(PC, PetscInt *, Mat *[]); 237f746d493SDmitry Karpeev 238014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCCompositeSetType(PC, PCCompositeType); 239c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCCompositeGetType(PC, PCCompositeType *); 2408aa07aa6SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCCompositeAddPCType(PC, PCType); 2418aa07aa6SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCCompositeAddPC(PC, PC); 2428e6eba06SBarry Smith PETSC_EXTERN PetscErrorCode PCCompositeGetNumberPC(PC, PetscInt *); 243014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCCompositeGetPC(PC, PetscInt, PC *); 244014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCCompositeSpecialSetAlpha(PC, PetscScalar); 245981c4779SBarry Smith 246014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCRedundantSetNumber(PC, PetscInt); 247014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCRedundantSetScatter(PC, VecScatter, VecScatter); 248014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCRedundantGetOperators(PC, Mat *, Mat *); 249da3a660dSBarry Smith 250b03515a0SUmberto Zerbinati PETSC_EXTERN PetscErrorCode PCSPAISetEpsilon(PC, PetscReal); 251014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSPAISetNBSteps(PC, PetscInt); 252014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSPAISetMax(PC, PetscInt); 253014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSPAISetMaxNew(PC, PetscInt); 254014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSPAISetBlockSize(PC, PetscInt); 255014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSPAISetCacheSize(PC, PetscInt); 256014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSPAISetVerbose(PC, PetscInt); 257014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCSPAISetSp(PC, PetscInt); 2583304466cSBarry Smith 259014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCHYPRESetType(PC, const char[]); 260014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCHYPREGetType(PC, const char *[]); 2614cb006feSStefano Zampini PETSC_EXTERN PetscErrorCode PCHYPRESetDiscreteGradient(PC, Mat); 262863406b8SStefano Zampini PETSC_EXTERN PetscErrorCode PCHYPRESetDiscreteCurl(PC, Mat); 2636bf688a0SCe Qin PETSC_EXTERN PetscErrorCode PCHYPRESetInterpolations(PC, PetscInt, Mat, Mat[], Mat, Mat[]); 2644cb006feSStefano Zampini PETSC_EXTERN PetscErrorCode PCHYPRESetEdgeConstantVectors(PC, Vec, Vec, Vec); 265be14dc20SKerry Key PETSC_EXTERN PetscErrorCode PCHYPREAMSSetInteriorNodes(PC, Vec); 2664cb006feSStefano Zampini PETSC_EXTERN PetscErrorCode PCHYPRESetAlphaPoissonMatrix(PC, Mat); 2674cb006feSStefano Zampini PETSC_EXTERN PetscErrorCode PCHYPRESetBetaPoissonMatrix(PC, Mat); 2683304466cSBarry Smith 269014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFieldSplitSetFields(PC, const char[], PetscInt, const PetscInt *, const PetscInt *); 270014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFieldSplitSetType(PC, PCCompositeType); 271c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCFieldSplitGetType(PC, PCCompositeType *); 272014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFieldSplitSetBlockSize(PC, PetscInt); 273014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFieldSplitSetIS(PC, const char[], IS); 274014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFieldSplitGetIS(PC, const char[], IS *); 275998f007dSPierre Jolivet PETSC_EXTERN PetscErrorCode PCFieldSplitGetISByIndex(PC, PetscInt, IS *); 2766dbb499eSCian Wilson PETSC_EXTERN PetscErrorCode PCFieldSplitRestrictIS(PC, IS); 2774ab8060aSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCFieldSplitSetDMSplits(PC, PetscBool); 2784ab8060aSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCFieldSplitGetDMSplits(PC, PetscBool *); 279c84da90fSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCFieldSplitSetDiagUseAmat(PC, PetscBool); 280c84da90fSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCFieldSplitGetDiagUseAmat(PC, PetscBool *); 281c84da90fSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCFieldSplitSetOffDiagUseAmat(PC, PetscBool); 282c84da90fSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCFieldSplitGetOffDiagUseAmat(PC, PetscBool *); 283c84da90fSDmitry Karpeev 28425ef9dfeSBarry Smith PETSC_EXTERN PETSC_DEPRECATED_FUNCTION("Use PCFieldSplitSetSchurPre() (since version 3.5)") PetscErrorCode PCFieldSplitSchurPrecondition(PC, PCFieldSplitSchurPreType, Mat); 28529f8a81cSJed Brown PETSC_EXTERN PetscErrorCode PCFieldSplitSetSchurPre(PC, PCFieldSplitSchurPreType, Mat); 28637a82bf0SJed Brown PETSC_EXTERN PetscErrorCode PCFieldSplitGetSchurPre(PC, PCFieldSplitSchurPreType *, Mat *); 287014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFieldSplitSetSchurFactType(PC, PCFieldSplitSchurFactType); 288c096484dSStefano Zampini PETSC_EXTERN PetscErrorCode PCFieldSplitSetSchurScale(PC, PetscScalar); 289014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCFieldSplitGetSchurBlocks(PC, Mat *, Mat *, Mat *, Mat *); 290470b340bSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCFieldSplitSchurGetS(PC, Mat *S); 291470b340bSDmitry Karpeev PETSC_EXTERN PetscErrorCode PCFieldSplitSchurRestoreS(PC, Mat *S); 2927b752e3dSPatrick Sanan PETSC_EXTERN PetscErrorCode PCFieldSplitGetDetectSaddlePoint(PC, PetscBool *); 2937b752e3dSPatrick Sanan PETSC_EXTERN PetscErrorCode PCFieldSplitSetDetectSaddlePoint(PC, PetscBool); 294b09e027eSCarola Kruse PETSC_EXTERN PetscErrorCode PCFieldSplitSetGKBTol(PC, PetscReal); 295b09e027eSCarola Kruse PETSC_EXTERN PetscErrorCode PCFieldSplitSetGKBNu(PC, PetscReal); 296b09e027eSCarola Kruse PETSC_EXTERN PetscErrorCode PCFieldSplitSetGKBMaxit(PC, PetscInt); 297b09e027eSCarola Kruse PETSC_EXTERN PetscErrorCode PCFieldSplitSetGKBDelay(PC, PetscInt); 2983d30b1ffSBarry Smith 299014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGalerkinSetRestriction(PC, Mat); 300014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGalerkinSetInterpolation(PC, Mat); 301b3402f20SBarry Smith PETSC_EXTERN PetscErrorCode PCGalerkinSetComputeSubmatrix(PC, PetscErrorCode (*)(PC, Mat, Mat, Mat *, void *), void *); 3022a6744ebSBarry Smith 303014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCPythonSetType(PC, const char[]); 304ebead697SStefano Zampini PETSC_EXTERN PetscErrorCode PCPythonGetType(PC, const char *[]); 30567fac13cSBarry Smith 306baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCPARMSSetGlobal(PC, PCPARMSGlobalType); 307baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCPARMSSetLocal(PC, PCPARMSLocalType); 308baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCPARMSSetSolveTolerances(PC, PetscReal, PetscInt); 309baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCPARMSSetSolveRestart(PC, PetscInt); 310baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCPARMSSetNonsymPerm(PC, PetscBool); 311baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCPARMSSetFill(PC, PetscInt, PetscInt, PetscInt); 31237f80224SJose E. Roman 313c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCGAMGSetType(PC, PCGAMGType); 314c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCGAMGGetType(PC, PCGAMGType *); 315014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGAMGSetProcEqLim(PC, PetscInt); 31618c3aa7eSMark 317cab9ed1eSBarry Smith PETSC_EXTERN PetscErrorCode PCGAMGSetRepartition(PC, PetscBool); 31818c3aa7eSMark PETSC_EXTERN PetscErrorCode PCGAMGSetUseSAEstEig(PC, PetscBool); 31918c3aa7eSMark PETSC_EXTERN PetscErrorCode PCGAMGSetEigenvalues(PC, PetscReal, PetscReal); 320cab9ed1eSBarry Smith PETSC_EXTERN PetscErrorCode PCGAMGASMSetUseAggs(PC, PetscBool); 321171cca9aSMark Adams PETSC_EXTERN PetscErrorCode PCGAMGSetUseParallelCoarseGridSolve(PC, PetscBool); 322ce7c7f2fSMark Adams PETSC_EXTERN PetscErrorCode PCGAMGSetCpuPinCoarseGrids(PC, PetscBool); 323ce7c7f2fSMark Adams PETSC_EXTERN PetscErrorCode PCGAMGSetCoarseGridLayoutType(PC, PCGAMGLayoutType); 324c1eae691SMark Adams PETSC_EXTERN PetscErrorCode PCGAMGSetThreshold(PC, PetscReal[], PetscInt); 325c9567895SMark PETSC_EXTERN PetscErrorCode PCGAMGSetRankReductionFactors(PC, PetscInt[], PetscInt); 326c1eae691SMark Adams PETSC_EXTERN PetscErrorCode PCGAMGSetThresholdScale(PC, PetscReal); 327014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGAMGSetCoarseEqLim(PC, PetscInt); 328014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCGAMGSetNlevels(PC, PetscInt); 329baa89ecbSBarry Smith PETSC_EXTERN PetscErrorCode PCGAMGSetNSmooths(PC, PetscInt); 3309ab59c8bSMark Adams PETSC_EXTERN PetscErrorCode PCGAMGSetSquareGraph(PC, PetscInt); 331bae903cbSmarkadams4 PETSC_EXTERN PetscErrorCode PCGAMGSetAggressiveLevels(PC, PetscInt); 3321cc46a46SBarry Smith PETSC_EXTERN PetscErrorCode PCGAMGSetReuseInterpolation(PC, PetscBool); 3333e3471ccSMark Adams PETSC_EXTERN PetscErrorCode PCGAMGFinalizePackage(void); 3343e3471ccSMark Adams PETSC_EXTERN PetscErrorCode PCGAMGInitializePackage(void); 335a36cf38bSToby Isaac PETSC_EXTERN PetscErrorCode PCGAMGRegister(PCGAMGType, PetscErrorCode (*)(PC)); 3362d776b49SBarry Smith PETSC_EXTERN PetscErrorCode PCGAMGCreateGraph(PC, Mat, Mat *); 33756de70efSSatish Balay 3388eab0cc1SPeter Brune PETSC_EXTERN PetscErrorCode PCGAMGClassicalSetType(PC, PCGAMGClassicalType); 339c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCGAMGClassicalGetType(PC, PCGAMGClassicalType *); 3408eab0cc1SPeter Brune 3411e0482f5SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCSetDiscreteGradient(PC, Mat, PetscInt, PetscInt, PetscBool, PetscBool); 3428ae0ca82SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCSetDivergenceMat(PC, Mat, PetscBool, IS); 3431dd7afcfSStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCSetChangeOfBasisMat(PC, Mat, PetscBool); 34430368db7SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCSetPrimalVerticesIS(PC, IS); 345674ae819SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCSetPrimalVerticesLocalIS(PC, IS); 3463100ebe3SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCGetPrimalVerticesIS(PC, IS *); 3473100ebe3SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCGetPrimalVerticesLocalIS(PC, IS *); 3484fad6a16SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCSetCoarseningRatio(PC, PetscInt); 3492b510759SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCSetLevels(PC, PetscInt); 350014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCBDDCSetDirichletBoundaries(PC, IS); 35182ba6b80SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCSetDirichletBoundariesLocal(PC, IS); 352014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCBDDCGetDirichletBoundaries(PC, IS *); 35382ba6b80SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCGetDirichletBoundariesLocal(PC, IS *); 354bc960bbfSJed Brown PETSC_EXTERN PetscErrorCode PCBDDCSetInterfaceExtType(PC, PCBDDCInterfaceExtType); 355014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCBDDCSetNeumannBoundaries(PC, IS); 35682ba6b80SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCSetNeumannBoundariesLocal(PC, IS); 357014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCBDDCGetNeumannBoundaries(PC, IS *); 35882ba6b80SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCGetNeumannBoundariesLocal(PC, IS *); 359014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCBDDCSetDofsSplitting(PC, PetscInt, IS[]); 36063602bcaSStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCSetDofsSplittingLocal(PC, PetscInt, IS[]); 3611a83f524SJed Brown PETSC_EXTERN PetscErrorCode PCBDDCSetLocalAdjacencyGraph(PC, PetscInt, const PetscInt[], const PetscInt[], PetscCopyMode); 362547c9a8eSstefano_zampini PETSC_EXTERN PetscErrorCode PCBDDCCreateFETIDPOperators(PC, PetscBool, const char *, Mat *, PC *); 3633425bc38SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCMatFETIDPGetRHS(Mat, Vec, Vec); 3643425bc38SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCMatFETIDPGetSolution(Mat, Vec, Vec); 36543371fb9SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCFinalizePackage(void); 36643371fb9SStefano Zampini PETSC_EXTERN PetscErrorCode PCBDDCInitializePackage(void); 3670c7d97c5SJed Brown 368b965d45eSStefano Zampini PETSC_EXTERN PetscErrorCode PCISSetUseStiffnessScaling(PC, PetscBool); 369014dd563SJed Brown PETSC_EXTERN PetscErrorCode PCISSetSubdomainScalingFactor(PC, PetscScalar); 37046caae47SJed Brown PETSC_EXTERN PetscErrorCode PCISSetSubdomainDiagonalScaling(PC, Vec); 371d3b1e0e7SMatthew Knepley 372ab83eea4SMatthew G. Knepley PETSC_EXTERN PetscInt PetscMGLevelId; 373b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetType(PC, PCMGType); 374c60c7ad4SBarry Smith PETSC_EXTERN PetscErrorCode PCMGGetType(PC, PCMGType *); 375b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetLevels(PC, PetscInt, MPI_Comm *); 376b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGGetLevels(PC, PetscInt *); 377b4876bcbSBarry Smith 378f442ab6aSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetDistinctSmoothUp(PC); 37906792cafSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetNumberSmooth(PC, PetscInt); 380b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetCycleType(PC, PCMGCycleType); 381b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetCycleTypeOnLevel(PC, PetscInt, PCMGCycleType); 382d71ae5a4SJacob Faibussowitsch PETSC_DEPRECATED_FUNCTION("Use PCMGSetCycleTypeOnLevel() (since version 3.5)") static inline PetscErrorCode PCMGSetCyclesOnLevel(PC pc, PetscInt l, PetscInt t) 383d71ae5a4SJacob Faibussowitsch { 3849371c9d4SSatish Balay return PCMGSetCycleTypeOnLevel(pc, l, (PCMGCycleType)t); 3859371c9d4SSatish Balay } 386b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGMultiplicativeSetCycles(PC, PetscInt); 3872134b1e4SBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetGalerkin(PC, PCMGGalerkinType); 3882134b1e4SBarry Smith PETSC_EXTERN PetscErrorCode PCMGGetGalerkin(PC, PCMGGalerkinType *); 3892b3cbbdaSStefano Zampini PETSC_EXTERN PetscErrorCode PCMGSetAdaptCoarseSpaceType(PC, PCMGCoarseSpaceType); 3902b3cbbdaSStefano Zampini PETSC_EXTERN PetscErrorCode PCMGGetAdaptCoarseSpaceType(PC, PCMGCoarseSpaceType *); 39141b6fd38SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCMGSetAdaptCR(PC, PetscBool); 39241b6fd38SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCMGGetAdaptCR(PC, PetscBool *); 3932b3cbbdaSStefano Zampini /* MATT: Remove? */ 3942b3cbbdaSStefano Zampini PETSC_EXTERN PetscErrorCode PCMGSetAdaptInterpolation(PC, PetscBool); 3952b3cbbdaSStefano Zampini PETSC_EXTERN PetscErrorCode PCMGGetAdaptInterpolation(PC, PetscBool *); 396b4876bcbSBarry Smith 397b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetRhs(PC, PetscInt, Vec); 398b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetX(PC, PetscInt, Vec); 399b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetR(PC, PetscInt, Vec); 400b4876bcbSBarry Smith 401b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetRestriction(PC, PetscInt, Mat); 402b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGGetRestriction(PC, PetscInt, Mat *); 403eab52d2bSLawrence Mitchell PETSC_EXTERN PetscErrorCode PCMGSetInjection(PC, PetscInt, Mat); 404eab52d2bSLawrence Mitchell PETSC_EXTERN PetscErrorCode PCMGGetInjection(PC, PetscInt, Mat *); 405b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetInterpolation(PC, PetscInt, Mat); 4068a2c336bSFande Kong PETSC_EXTERN PetscErrorCode PCMGSetOperators(PC, PetscInt, Mat, Mat); 407b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGGetInterpolation(PC, PetscInt, Mat *); 408b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetRScale(PC, PetscInt, Vec); 409b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGGetRScale(PC, PetscInt, Vec *); 410b4876bcbSBarry Smith PETSC_EXTERN PetscErrorCode PCMGSetResidual(PC, PetscInt, PetscErrorCode (*)(Mat, Vec, Vec, Vec), Mat); 411fcb023d4SJed Brown PETSC_EXTERN PetscErrorCode PCMGSetResidualTranspose(PC, PetscInt, PetscErrorCode (*)(Mat, Vec, Vec, Vec), Mat); 41254b2cd4bSJed Brown PETSC_EXTERN PetscErrorCode PCMGResidualDefault(Mat, Vec, Vec, Vec); 413fcb023d4SJed Brown PETSC_EXTERN PetscErrorCode PCMGResidualTransposeDefault(Mat, Vec, Vec, Vec); 41430b0564aSStefano Zampini PETSC_EXTERN PetscErrorCode PCMGMatResidualDefault(Mat, Mat, Mat, Mat); 41530b0564aSStefano Zampini PETSC_EXTERN PetscErrorCode PCMGMatResidualTransposeDefault(Mat, Mat, Mat, Mat); 416db6f9c32SMark Adams PETSC_EXTERN PetscErrorCode PCMGGalerkinSetMatProductAlgorithm(PC, const char[]); 417db6f9c32SMark Adams PETSC_EXTERN PetscErrorCode PCMGGalerkinGetMatProductAlgorithm(PC, const char *[]); 418e7d4b4cbSMark Adams PETSC_EXTERN PetscErrorCode PCMGGetGridComplexity(PC, PetscReal *, PetscReal *); 419e75ffff3SFande Kong 4208a2c336bSFande Kong PETSC_EXTERN PetscErrorCode PCHMGSetReuseInterpolation(PC, PetscBool); 4218a2c336bSFande Kong PETSC_EXTERN PetscErrorCode PCHMGSetUseSubspaceCoarsening(PC, PetscBool); 4228a2c336bSFande Kong PETSC_EXTERN PetscErrorCode PCHMGSetInnerPCType(PC, PCType); 4234fea3358SFande Kong PETSC_EXTERN PetscErrorCode PCHMGSetCoarseningComponent(PC, PetscInt); 4244fea3358SFande Kong PETSC_EXTERN PetscErrorCode PCHMGUseMatMAIJ(PC, PetscBool); 4258a2c336bSFande Kong 42648a10b22SPatrick Sanan PETSC_EXTERN PetscErrorCode PCTelescopeGetSubcommType(PC, PetscSubcommType *); 42748a10b22SPatrick Sanan PETSC_EXTERN PetscErrorCode PCTelescopeSetSubcommType(PC, PetscSubcommType); 42868ddcbeaSBarry Smith PETSC_EXTERN PetscErrorCode PCTelescopeGetReductionFactor(PC, PetscInt *); 42968ddcbeaSBarry Smith PETSC_EXTERN PetscErrorCode PCTelescopeSetReductionFactor(PC, PetscInt); 43068ddcbeaSBarry Smith PETSC_EXTERN PetscErrorCode PCTelescopeGetIgnoreDM(PC, PetscBool *); 431bfd6bcc6SSatish Balay PETSC_EXTERN PetscErrorCode PCTelescopeSetIgnoreDM(PC, PetscBool); 43234fb549aSDave May PETSC_EXTERN PetscErrorCode PCTelescopeGetUseCoarseDM(PC, PetscBool *); 43334fb549aSDave May PETSC_EXTERN PetscErrorCode PCTelescopeSetUseCoarseDM(PC, PetscBool); 4340ae7c45bSDave May PETSC_EXTERN PetscErrorCode PCTelescopeGetIgnoreKSPComputeOperators(PC, PetscBool *); 4350ae7c45bSDave May PETSC_EXTERN PetscErrorCode PCTelescopeSetIgnoreKSPComputeOperators(PC, PetscBool); 43668ddcbeaSBarry Smith PETSC_EXTERN PetscErrorCode PCTelescopeGetDM(PC, DM *); 4376ab51f8fSDave May 4384bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchSetSaveOperators(PC, PetscBool); 4394bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchGetSaveOperators(PC, PetscBool *); 440fa84ea4cSLawrence Mitchell PETSC_EXTERN PetscErrorCode PCPatchSetPrecomputeElementTensors(PC, PetscBool); 441fa84ea4cSLawrence Mitchell PETSC_EXTERN PetscErrorCode PCPatchGetPrecomputeElementTensors(PC, PetscBool *); 4424bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchSetPartitionOfUnity(PC, PetscBool); 4434bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchGetPartitionOfUnity(PC, PetscBool *); 4444bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchSetSubMatType(PC, MatType); 4454bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchGetSubMatType(PC, MatType *); 4464bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchSetCellNumbering(PC, PetscSection); 4474bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchGetCellNumbering(PC, PetscSection *); 4484bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchSetConstructType(PC, PCPatchConstructType, PetscErrorCode (*)(PC, PetscInt *, IS **, IS *, void *), void *); 4494bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchGetConstructType(PC, PCPatchConstructType *, PetscErrorCode (**)(PC, PetscInt *, IS **, IS *, void *), void **); 4504bbf5ea8SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCPatchSetDiscretisationInfo(PC, PetscInt, DM *, PetscInt *, PetscInt *, const PetscInt **, const PetscInt *, PetscInt, const PetscInt *, PetscInt, const PetscInt *); 4514d04e9f1SPatrick Farrell PETSC_EXTERN PetscErrorCode PCPatchSetComputeOperator(PC, PetscErrorCode (*)(PC, PetscInt, Vec, Mat, IS, PetscInt, const PetscInt *, const PetscInt *, void *), void *); 45239fd2e8aSPatrick Farrell PETSC_EXTERN PetscErrorCode PCPatchSetComputeFunction(PC pc, PetscErrorCode (*func)(PC, PetscInt, Vec, Vec, IS, PetscInt, const PetscInt *, const PetscInt *, void *), void *ctx); 45359109abcSLawrence Mitchell PETSC_EXTERN PetscErrorCode PCPatchSetComputeOperatorInteriorFacets(PC, PetscErrorCode (*)(PC, PetscInt, Vec, Mat, IS, PetscInt, const PetscInt *, const PetscInt *, void *), void *); 45459109abcSLawrence Mitchell PETSC_EXTERN PetscErrorCode PCPatchSetComputeFunctionInteriorFacets(PC pc, PetscErrorCode (*func)(PC, PetscInt, Vec, Vec, IS, PetscInt, const PetscInt *, const PetscInt *, void *), void *ctx); 4554bbf5ea8SMatthew G. Knepley 456b9ac7092SAlp Dener PETSC_EXTERN PetscErrorCode PCLMVMSetMatLMVM(PC, Mat); 457b9ac7092SAlp Dener PETSC_EXTERN PetscErrorCode PCLMVMGetMatLMVM(PC, Mat *); 458b9ac7092SAlp Dener PETSC_EXTERN PetscErrorCode PCLMVMSetIS(PC, IS); 459b9ac7092SAlp Dener PETSC_EXTERN PetscErrorCode PCLMVMClearIS(PC); 460b9ac7092SAlp Dener 4617ede41a2SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PCExoticSetType(PC, PCExoticType); 4627ede41a2SMatthew G. Knepley 463a122ebaeSJakub Kruzik PETSC_EXTERN PetscErrorCode PCDeflationSetInitOnly(PC, PetscBool); 46493b79a5aSJakub Kruzik PETSC_EXTERN PetscErrorCode PCDeflationSetLevels(PC, PetscInt); 465859a873cSJakub Kruzik PETSC_EXTERN PetscErrorCode PCDeflationSetReductionFactor(PC, PetscInt); 4668a71cb68SJakub Kruzik PETSC_EXTERN PetscErrorCode PCDeflationSetCorrectionFactor(PC, PetscScalar); 46739417d7eSJakub Kruzik PETSC_EXTERN PetscErrorCode PCDeflationSetSpaceToCompute(PC, PCDeflationSpaceType, PetscInt); 468e662bc50SJakub Kruzik PETSC_EXTERN PetscErrorCode PCDeflationSetSpace(PC, Mat, PetscBool); 46998d6e3deSJakub Kruzik PETSC_EXTERN PetscErrorCode PCDeflationSetProjectionNullSpaceMat(PC, Mat); 47098d6e3deSJakub Kruzik PETSC_EXTERN PetscErrorCode PCDeflationSetCoarseMat(PC, Mat); 471268c6673SJakub Kruzik PETSC_EXTERN PetscErrorCode PCDeflationGetPC(PC, PC *); 47298d6e3deSJakub Kruzik 47338cfc46eSPierre Jolivet PETSC_EXTERN PetscErrorCode PCHPDDMSetAuxiliaryMat(PC, IS, Mat, PetscErrorCode (*)(Mat, PetscReal, Vec, Vec, PetscReal, IS, void *), void *); 474244dff2eSPierre Jolivet PETSC_EXTERN PetscErrorCode PCHPDDMSetRHSMat(PC, Mat); 475c5910190SPierre Jolivet PETSC_EXTERN PetscErrorCode PCHPDDMHasNeumannMat(PC, PetscBool); 47638cfc46eSPierre Jolivet PETSC_EXTERN PetscErrorCode PCHPDDMSetCoarseCorrectionType(PC, PCHPDDMCoarseCorrectionType); 47738cfc46eSPierre Jolivet PETSC_EXTERN PetscErrorCode PCHPDDMGetCoarseCorrectionType(PC, PCHPDDMCoarseCorrectionType *); 478e31fc274SPierre Jolivet PETSC_EXTERN PetscErrorCode PCHPDDMSetSTShareSubKSP(PC, PetscBool); 479dfad241bSPierre Jolivet PETSC_EXTERN PetscErrorCode PCHPDDMGetSTShareSubKSP(PC, PetscBool *); 4802e65eb73SPierre Jolivet PETSC_EXTERN PetscErrorCode PCHPDDMSetDeflationMat(PC, IS, Mat); 48105b34211SPierre Jolivet PETSC_EXTERN PetscErrorCode PCHPDDMFinalizePackage(void); 48205b34211SPierre Jolivet PETSC_EXTERN PetscErrorCode PCHPDDMInitializePackage(void); 48338cfc46eSPierre Jolivet 484e6f8f311SMark Adams PETSC_EXTERN PetscErrorCode PCAmgXGetResources(PC, void *); 485e6f8f311SMark Adams 48626bd1501SBarry Smith #endif /* PETSCPC_H */ 487