xref: /petsc/src/snes/interface/snesregi.c (revision 41ba4c6c04ec6b90096e1e0d2d3de306864f2fe5)
1eaa2832dSBarry Smith 
2af0996ceSBarry Smith #include <petsc/private/snesimpl.h>     /*I  "petscsnes.h"  I*/
3fb2e594dSBarry Smith 
48cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_NEWTONLS(SNES);
58cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_NEWTONTR(SNES);
6*41ba4c6cSHeeho Park PETSC_EXTERN PetscErrorCode SNESCreate_NEWTONTRDC(SNES);
78cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_NRichardson(SNES);
88cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_KSPONLY(SNES);
91ef27442SStefano Zampini PETSC_EXTERN PetscErrorCode SNESCreate_KSPTRANSPOSEONLY(SNES);
108cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_VINEWTONRSLS(SNES);
118cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_VINEWTONSSLS(SNES);
128cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_NGMRES(SNES);
138cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_QN(SNES);
148cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_Shell(SNES);
15be95d8f1SBarry Smith PETSC_EXTERN PetscErrorCode SNESCreate_NGS(SNES);
168cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_NCG(SNES);
178cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_FAS(SNES);
188cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_MS(SNES);
198cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_NASM(SNES);
208cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_Anderson(SNES);
218cc058d9SJed Brown PETSC_EXTERN PetscErrorCode SNESCreate_ASPIN(SNES);
22eed5f15bSPeter Brune PETSC_EXTERN PetscErrorCode SNESCreate_Composite(SNES);
23561742edSMatthew G. Knepley PETSC_EXTERN PetscErrorCode SNESCreate_Patch(SNES);
24eaa2832dSBarry Smith 
251c6b2ff8SBarry Smith const char *SNESConvergedReasons_Shifted[] = {" ","DIVERGED_TR_DELTA","DIVERGED_JACOBIAN_DOMAIN","DIVERGED_DTOL","DIVERGED_LOCAL_MIN","DIVERGED_INNER","DIVERGED_LINE_SEARCH","DIVERGED_MAX_IT",
2664075487SBarry Smith                                               "DIVERGED_FNORM_NAN","DIVERGED_LINEAR_SOLVE","DIVERGED_FUNCTION_COUNT","DIVERGED_FUNCTION_DOMAIN",
279dcbbd2bSBarry Smith                                               "CONVERGED_ITERATING"," ","CONVERGED_FNORM_ABS","CONVERGED_FNORM_RELATIVE",
289e5d0892SLisandro Dalcin                                               "CONVERGED_SNORM_RELATIVE","CONVERGED_ITS"," ","SNESConvergedReason","",NULL};
291c6b2ff8SBarry Smith const char *const *SNESConvergedReasons = SNESConvergedReasons_Shifted + 12;
309dcbbd2bSBarry Smith 
319e5d0892SLisandro Dalcin const char *SNESNormSchedules_Shifted[]    = {"DEFAULT","NONE","ALWAYS","INITIALONLY","FINALONLY","INITIALFINALONLY","SNESNormSchedule","SNES_NORM_",NULL};
32365a6726SPeter Brune const char *const *const SNESNormSchedules = SNESNormSchedules_Shifted + 1;
33fdacfa88SPeter Brune 
349e5d0892SLisandro Dalcin const char *SNESFunctionTypes_Shifted[]    = {"DEFAULT","UNPRECONDITIONED","PRECONDITIONED","SNESFunctionType","SNES_FUNCTION_",NULL};
3547073ea2SPeter Brune const char *const *const SNESFunctionTypes = SNESFunctionTypes_Shifted + 1;
3647073ea2SPeter Brune 
3783f0b094SBarry Smith /*@C
3882bf6240SBarry Smith    SNESRegisterAll - Registers all of the nonlinear solver methods in the SNES package.
39eaa2832dSBarry Smith 
40fee21e36SBarry Smith    Not Collective
41fee21e36SBarry Smith 
4236851e7fSLois Curfman McInnes    Level: advanced
4336851e7fSLois Curfman McInnes 
4482bf6240SBarry Smith .seealso:  SNESRegisterDestroy()
45eaa2832dSBarry Smith @*/
46607a6623SBarry Smith PetscErrorCode  SNESRegisterAll(void)
47eaa2832dSBarry Smith {
48dfbe8321SBarry Smith   PetscErrorCode ierr;
4982bf6240SBarry Smith 
503a40ed3dSBarry Smith   PetscFunctionBegin;
510f51fdf8SToby Isaac   if (SNESRegisterAllCalled) PetscFunctionReturn(0);
524c49b128SBarry Smith   SNESRegisterAllCalled = PETSC_TRUE;
5382bf6240SBarry Smith 
54bdf89e91SBarry Smith   ierr = SNESRegister(SNESNEWTONLS,         SNESCreate_NEWTONLS);CHKERRQ(ierr);
55bdf89e91SBarry Smith   ierr = SNESRegister(SNESNEWTONTR,         SNESCreate_NEWTONTR);CHKERRQ(ierr);
56*41ba4c6cSHeeho Park   ierr = SNESRegister(SNESNEWTONTRDC,       SNESCreate_NEWTONTRDC);CHKERRQ(ierr);
57bdf89e91SBarry Smith   ierr = SNESRegister(SNESNRICHARDSON,      SNESCreate_NRichardson);CHKERRQ(ierr);
58bdf89e91SBarry Smith   ierr = SNESRegister(SNESKSPONLY,          SNESCreate_KSPONLY);CHKERRQ(ierr);
591ef27442SStefano Zampini   ierr = SNESRegister(SNESKSPTRANSPOSEONLY, SNESCreate_KSPTRANSPOSEONLY);CHKERRQ(ierr);
60bdf89e91SBarry Smith   ierr = SNESRegister(SNESVINEWTONRSLS,     SNESCreate_VINEWTONRSLS);CHKERRQ(ierr);
61bdf89e91SBarry Smith   ierr = SNESRegister(SNESVINEWTONSSLS,     SNESCreate_VINEWTONSSLS);CHKERRQ(ierr);
62bdf89e91SBarry Smith   ierr = SNESRegister(SNESNGMRES,           SNESCreate_NGMRES);CHKERRQ(ierr);
63bdf89e91SBarry Smith   ierr = SNESRegister(SNESQN,               SNESCreate_QN);CHKERRQ(ierr);
64bdf89e91SBarry Smith   ierr = SNESRegister(SNESSHELL,            SNESCreate_Shell);CHKERRQ(ierr);
65be95d8f1SBarry Smith   ierr = SNESRegister(SNESNGS,              SNESCreate_NGS);CHKERRQ(ierr);
66bdf89e91SBarry Smith   ierr = SNESRegister(SNESNCG,              SNESCreate_NCG);CHKERRQ(ierr);
67bdf89e91SBarry Smith   ierr = SNESRegister(SNESFAS,              SNESCreate_FAS);CHKERRQ(ierr);
68bdf89e91SBarry Smith   ierr = SNESRegister(SNESMS,               SNESCreate_MS);CHKERRQ(ierr);
69bdf89e91SBarry Smith   ierr = SNESRegister(SNESNASM,             SNESCreate_NASM);CHKERRQ(ierr);
70bdf89e91SBarry Smith   ierr = SNESRegister(SNESANDERSON,         SNESCreate_Anderson);CHKERRQ(ierr);
71bdf89e91SBarry Smith   ierr = SNESRegister(SNESASPIN,            SNESCreate_ASPIN);CHKERRQ(ierr);
72eed5f15bSPeter Brune   ierr = SNESRegister(SNESCOMPOSITE,        SNESCreate_Composite);CHKERRQ(ierr);
73561742edSMatthew G. Knepley   ierr = SNESRegister(SNESPATCH,            SNESCreate_Patch);CHKERRQ(ierr);
74798534f6SMatthew G. Knepley 
75798534f6SMatthew G. Knepley   ierr = KSPMonitorRegister("snes_preconditioned_residual", PETSCVIEWERASCII, PETSC_VIEWER_DEFAULT, KSPMonitorSNESResidual,       NULL, NULL);CHKERRQ(ierr);
76798534f6SMatthew G. Knepley   ierr = KSPMonitorRegister("snes_preconditioned_residual", PETSCVIEWERDRAW,  PETSC_VIEWER_DRAW_LG, KSPMonitorSNESResidualDrawLG, KSPMonitorSNESResidualDrawLGCreate, NULL);CHKERRQ(ierr);
773a40ed3dSBarry Smith   PetscFunctionReturn(0);
78eaa2832dSBarry Smith }
79