Actual source code: snesshell.c
petsc-3.10.5 2019-03-28
1: #include <petsc/private/snesimpl.h>
3: typedef struct {PetscErrorCode (*solve)(SNES,Vec);void *ctx;} SNES_Shell;
5: /*@C
6: SNESShellSetSolve - Sets routine to apply as solver
8: Logically Collective on SNES
10: Input Parameters:
11: + snes - the nonlinear solver context
12: - apply - the application-provided solver routine
14: Calling sequence of solve:
15: .vb
16: PetscErrorCode apply (SNES snes,Vec xout)
17: .ve
19: + snes - the preconditioner, get the application context with SNESShellGetContext()
20: - xout - solution vector
22: Notes:
23: the function MUST return an error code of 0 on success and nonzero on failure.
25: Level: advanced
27: .keywords: SNES, shell, set, apply, user-provided
29: .seealso: SNESSHELL, SNESShellSetContext(), SNESShellGetContext()
30: @*/
31: PetscErrorCode SNESShellSetSolve(SNES snes,PetscErrorCode (*solve)(SNES,Vec))
32: {
37: PetscTryMethod(snes,"SNESShellSetSolve_C",(SNES,PetscErrorCode (*)(SNES,Vec)),(snes,solve));
38: return(0);
39: }
41: PetscErrorCode SNESReset_Shell(SNES snes)
42: {
44: return(0);
45: }
47: PetscErrorCode SNESDestroy_Shell(SNES snes)
48: {
52: SNESReset_Shell(snes);
53: PetscFree(snes->data);
54: return(0);
55: }
57: PetscErrorCode SNESSetUp_Shell(SNES snes)
58: {
60: return(0);
61: }
63: PetscErrorCode SNESSetFromOptions_Shell(PetscOptionItems *PetscOptionsObject,SNES snes)
64: {
68: PetscOptionsHead(PetscOptionsObject,"SNES Shell options");
69: return(0);
70: }
72: PetscErrorCode SNESView_Shell(SNES snes, PetscViewer viewer)
73: {
75: return(0);
76: }
78: /*@
79: SNESShellGetContext - Returns the user-provided context associated with a shell SNES
81: Not Collective
83: Input Parameter:
84: . snes - should have been created with SNESSetType(snes,SNESSHELL);
86: Output Parameter:
87: . ctx - the user provided context
89: Level: advanced
91: Notes:
92: This routine is intended for use within various shell routines
94: .keywords: SNES, shell, get, context
96: .seealso: SNESCreateShell(), SNESShellSetContext()
97: @*/
98: PetscErrorCode SNESShellGetContext(SNES snes,void **ctx)
99: {
101: PetscBool flg;
106: PetscObjectTypeCompare((PetscObject)snes,SNESSHELL,&flg);
107: if (!flg) *ctx = 0;
108: else *ctx = ((SNES_Shell*)(snes->data))->ctx;
109: return(0);
110: }
112: /*@
113: SNESShellSetContext - sets the context for a shell SNES
115: Logically Collective on SNES
117: Input Parameters:
118: + snes - the shell SNES
119: - ctx - the context
121: Level: advanced
123: Fortran Notes:
124: The context can only be an integer or a PetscObject
125: unfortunately it cannot be a Fortran array or derived type.
128: .seealso: SNESCreateShell(), SNESShellGetContext()
129: @*/
130: PetscErrorCode SNESShellSetContext(SNES snes,void *ctx)
131: {
132: SNES_Shell *shell = (SNES_Shell*)snes->data;
134: PetscBool flg;
138: PetscObjectTypeCompare((PetscObject)snes,SNESSHELL,&flg);
139: if (flg) shell->ctx = ctx;
140: return(0);
141: }
143: PetscErrorCode SNESSolve_Shell(SNES snes)
144: {
145: SNES_Shell *shell = (SNES_Shell*) snes->data;
149: if (!shell->solve) SETERRQ(PetscObjectComm((PetscObject)snes),PETSC_ERR_ARG_WRONGSTATE,"Must call SNESShellSetSolve() first");
150: snes->reason = SNES_CONVERGED_ITS;
151: (*shell->solve)(snes,snes->vec_sol);
152: return(0);
153: }
155: PetscErrorCode SNESShellSetSolve_Shell(SNES snes,PetscErrorCode (*solve)(SNES,Vec))
156: {
157: SNES_Shell *shell = (SNES_Shell*)snes->data;
160: shell->solve = solve;
161: return(0);
162: }
164: /*MC
165: SNESSHELL - a user provided nonlinear solver
167: Level: advanced
169: .seealso: SNESCreate(), SNES, SNESSetType(), SNESType (for list of available types)
170: M*/
172: PETSC_EXTERN PetscErrorCode SNESCreate_Shell(SNES snes)
173: {
174: SNES_Shell *shell;
178: snes->ops->destroy = SNESDestroy_Shell;
179: snes->ops->setup = SNESSetUp_Shell;
180: snes->ops->setfromoptions = SNESSetFromOptions_Shell;
181: snes->ops->view = SNESView_Shell;
182: snes->ops->solve = SNESSolve_Shell;
183: snes->ops->reset = SNESReset_Shell;
185: snes->usesksp = PETSC_FALSE;
186: snes->usesnpc = PETSC_FALSE;
188: snes->alwayscomputesfinalresidual = PETSC_FALSE;
190: PetscNewLog(snes,&shell);
191: snes->data = (void*) shell;
192: PetscObjectComposeFunction((PetscObject)snes,"SNESShellSetSolve_C",SNESShellSetSolve_Shell);
193: return(0);
194: }