Actual source code: pcbddcprivateimpl.h
1: /* prototypes of all BDDC private functions */
2: #pragma once
4: #include <petsc/private/pcbddcstructsimpl.h>
6: /* main functions */
7: PETSC_INTERN PetscErrorCode PCBDDCAnalyzeInterface(PC);
8: PETSC_INTERN PetscErrorCode PCBDDCConstraintsSetUp(PC);
10: /* load or dump customization */
11: PETSC_EXTERN PetscErrorCode PCBDDCLoadOrViewCustomization(PC, PetscBool, const char *);
13: /* reset functions */
14: PETSC_EXTERN PetscErrorCode PCBDDCResetTopography(PC);
15: PETSC_EXTERN PetscErrorCode PCBDDCResetSolvers(PC);
16: PETSC_EXTERN PetscErrorCode PCBDDCResetCustomization(PC);
18: /* graph */
19: PETSC_EXTERN PetscErrorCode PCBDDCGraphCreate(PCBDDCGraph *);
20: PETSC_EXTERN PetscErrorCode PCBDDCGraphDestroy(PCBDDCGraph *);
21: PETSC_EXTERN PetscErrorCode PCBDDCGraphInit(PCBDDCGraph, ISLocalToGlobalMapping, PetscInt, PetscInt);
22: PETSC_EXTERN PetscErrorCode PCBDDCGraphReset(PCBDDCGraph);
23: PETSC_EXTERN PetscErrorCode PCBDDCGraphResetCSR(PCBDDCGraph);
24: PETSC_EXTERN PetscErrorCode PCBDDCGraphResetCoords(PCBDDCGraph);
25: PETSC_EXTERN PetscErrorCode PCBDDCGraphSetUp(PCBDDCGraph, PetscInt, IS, IS, PetscInt, IS[], IS);
26: PETSC_EXTERN PetscErrorCode PCBDDCGraphComputeConnectedComponents(PCBDDCGraph);
27: PETSC_EXTERN PetscErrorCode PCBDDCGraphComputeConnectedComponentsLocal(PCBDDCGraph);
28: PETSC_EXTERN PetscErrorCode PCBDDCGraphASCIIView(PCBDDCGraph, PetscInt, PetscViewer);
29: PETSC_EXTERN PetscErrorCode PCBDDCGraphGetCandidatesIS(PCBDDCGraph, PetscInt *, IS *[], PetscInt *, IS *[], IS *);
30: PETSC_EXTERN PetscErrorCode PCBDDCGraphRestoreCandidatesIS(PCBDDCGraph, PetscInt *, IS *[], PetscInt *, IS *[], IS *);
31: PETSC_EXTERN PetscErrorCode PCBDDCGraphGetDirichletDofs(PCBDDCGraph, IS *);
32: PETSC_EXTERN PetscErrorCode PCBDDCGraphGetDirichletDofsB(PCBDDCGraph, IS *);
33: PETSC_EXTERN PetscCtxDestroyFn PCBDDCDestroyGraphCandidatesIS;
35: /* interface for scaling operator */
36: PETSC_INTERN PetscErrorCode PCBDDCScalingSetUp(PC);
37: PETSC_INTERN PetscErrorCode PCBDDCScalingDestroy(PC);
38: PETSC_INTERN PetscErrorCode PCBDDCScalingRestriction(PC, Vec, Vec);
39: PETSC_INTERN PetscErrorCode PCBDDCScalingExtension(PC, Vec, Vec);
41: /* nullspace correction */
42: PETSC_INTERN PetscErrorCode PCBDDCNullSpaceAssembleCorrection(PC, PetscBool, PetscBool);
44: /* utils */
45: PETSC_INTERN PetscErrorCode PCBDDCComputeLocalMatrix(PC, Mat);
46: PETSC_INTERN PetscErrorCode PCBDDCSetUpLocalWorkVectors(PC);
47: PETSC_INTERN PetscErrorCode PCBDDCSetUpSolvers(PC);
48: PETSC_INTERN PetscErrorCode PCBDDCSetUpLocalScatters(PC);
49: PETSC_INTERN PetscErrorCode PCBDDCSetUpLocalSolvers(PC, PetscBool, PetscBool);
50: PETSC_INTERN PetscErrorCode PCBDDCSetUpCorrection(PC, Mat *);
51: PETSC_INTERN PetscErrorCode PCBDDCSetUpCoarseSolver(PC, Mat);
52: PETSC_INTERN PetscErrorCode PCBDDCComputePrimalNumbering(PC, PetscInt *, PetscInt **);
53: PETSC_INTERN PetscErrorCode PCBDDCScatterCoarseDataBegin(PC, InsertMode, ScatterMode);
54: PETSC_INTERN PetscErrorCode PCBDDCScatterCoarseDataEnd(PC, InsertMode, ScatterMode);
55: PETSC_INTERN PetscErrorCode PCBDDCApplyInterfacePreconditioner(PC, PetscBool);
56: PETSC_INTERN PetscErrorCode PCBDDCOrthonormalizeVecs(PetscInt *, Vec[]);
57: PETSC_INTERN PetscErrorCode PCBDDCSetUseExactDirichlet(PC, PetscBool);
58: PETSC_INTERN PetscErrorCode PCBDDCSetLevel(PC, PetscInt);
59: PETSC_INTERN PetscErrorCode PCBDDCGlobalToLocal(VecScatter, Vec, Vec, IS, IS *);
60: PETSC_INTERN PetscErrorCode PCBDDCAdaptiveSelection(PC);
61: PETSC_INTERN PetscErrorCode PCBDDCConsistencyCheckIS(PC, MPI_Op, IS *);
62: PETSC_INTERN PetscErrorCode PCBDDCComputeLocalTopologyInfo(PC);
63: PETSC_INTERN PetscErrorCode PCBDDCDetectDisconnectedComponents(PC, PetscBool, PetscInt *, IS *[], IS *);
64: PETSC_INTERN PetscErrorCode PCBDDCReuseSolversBenignAdapt(PCBDDCReuseSolvers, Vec, Vec, PetscBool, PetscBool);
65: PETSC_INTERN PetscErrorCode PCBDDCComputeNoNetFlux(Mat, Mat, PetscBool, IS, PCBDDCGraph, MatNullSpace *);
66: PETSC_INTERN PetscErrorCode PCBDDCNullSpaceCreate(MPI_Comm, PetscBool, PetscInt, Vec[], MatNullSpace *);
67: PETSC_INTERN PetscErrorCode PCBDDCNedelecSupport(PC);
68: PETSC_INTERN PetscErrorCode PCBDDCAddPrimalVerticesLocalIS(PC, IS);
69: PETSC_INTERN PetscErrorCode PCBDDCComputeFakeChange(PC, PetscBool, PCBDDCGraph, PCBDDCSubSchurs, Mat *, IS *, IS *, PetscBool *);
70: PETSC_INTERN PetscErrorCode MatCreateSubMatrixUnsorted(Mat, IS, IS, Mat *);
71: PETSC_INTERN PetscErrorCode MatSeqAIJCompress(Mat, Mat *);
73: /* benign subspace trick */
74: PETSC_INTERN PetscErrorCode PCBDDCBenignPopOrPushB0(PC, PetscBool);
75: PETSC_INTERN PetscErrorCode PCBDDCBenignGetOrSetP0(PC, Vec, PetscBool);
76: PETSC_INTERN PetscErrorCode PCBDDCBenignDetectSaddlePoint(PC, PetscBool, IS *);
77: PETSC_INTERN PetscErrorCode PCBDDCBenignCheck(PC, IS);
78: PETSC_INTERN PetscErrorCode PCBDDCBenignShellMat(PC, PetscBool);
79: PETSC_INTERN PetscErrorCode PCBDDCBenignRemoveInterior(PC, Vec, Vec);
81: /* feti-dp */
82: PETSC_INTERN PetscErrorCode PCBDDCCreateFETIDPMatContext(PC, FETIDPMat_ctx *);
83: PETSC_INTERN PetscErrorCode PCBDDCSetupFETIDPMatContext(FETIDPMat_ctx);
84: PETSC_INTERN PetscErrorCode PCBDDCCreateFETIDPPCContext(PC, FETIDPPC_ctx *);
85: PETSC_INTERN PetscErrorCode PCBDDCSetupFETIDPPCContext(Mat, FETIDPPC_ctx);
86: PETSC_INTERN PetscErrorCode FETIDPPCApply(PC, Vec, Vec);
87: PETSC_INTERN PetscErrorCode FETIDPPCApplyTranspose(PC, Vec, Vec);
88: PETSC_INTERN PetscErrorCode FETIDPPCView(PC, PetscViewer);
89: PETSC_INTERN PetscErrorCode PCBDDCDestroyFETIDPPC(PC);
90: PETSC_INTERN PetscErrorCode FETIDPMatMult(Mat, Vec, Vec);
91: PETSC_INTERN PetscErrorCode FETIDPMatMultTranspose(Mat, Vec, Vec);
93: PETSC_INTERN PetscErrorCode PCBDDCDestroyFETIDPMat(Mat);
95: /* interface to SubSchurs */
96: PETSC_INTERN PetscErrorCode PCBDDCInitSubSchurs(PC);
97: PETSC_INTERN PetscErrorCode PCBDDCSetUpSubSchurs(PC);
99: /* sub schurs API */
100: PETSC_INTERN PetscErrorCode PCBDDCSubSchursCreate(PCBDDCSubSchurs *);
101: PETSC_INTERN PetscErrorCode PCBDDCSubSchursInit(PCBDDCSubSchurs, const char *, IS, IS, PCBDDCGraph, ISLocalToGlobalMapping, PetscBool, PetscBool);
102: PETSC_INTERN PetscErrorCode PCBDDCSubSchursReset(PCBDDCSubSchurs);
103: PETSC_INTERN PetscErrorCode PCBDDCSubSchursDestroy(PCBDDCSubSchurs *);
104: PETSC_INTERN PetscErrorCode PCBDDCSubSchursSetUp(PCBDDCSubSchurs, Mat, Mat, PetscBool, PetscInt[], PetscInt[], PetscInt, Vec, PetscBool, PetscBool, PetscBool, PetscInt, PetscInt[], IS[], Mat, IS);