1 2 #include <private/snesimpl.h> /*I "petscsnes.h" I*/ 3 4 EXTERN_C_BEGIN 5 extern PetscErrorCode SNESCreate_LS(SNES); 6 extern PetscErrorCode SNESCreate_TR(SNES); 7 extern PetscErrorCode SNESCreate_Test(SNES); 8 extern PetscErrorCode SNESCreate_NRichardson(SNES); 9 extern PetscErrorCode SNESCreate_KSPONLY(SNES); 10 extern PetscErrorCode SNESCreate_VIRS(SNES); 11 extern PetscErrorCode SNESCreate_VISS(SNES); 12 extern PetscErrorCode SNESCreate_NGMRES(SNES); 13 extern PetscErrorCode SNESCreate_SORQN(SNES); 14 extern PetscErrorCode SNESCreate_QN(SNES); 15 extern PetscErrorCode SNESCreate_Shell(SNES); 16 extern PetscErrorCode SNESCreate_GS(SNES); 17 extern PetscErrorCode SNESCreate_NCG(SNES); 18 extern PetscErrorCode SNESCreate_FAS(SNES); 19 EXTERN_C_END 20 21 const char *SNESConvergedReasons_Shifted[] = {" "," ","DIVERGED_LOCAL_MIN","DIVERGED_INNER","DIVERGED_LINE_SEARCH","DIVERGED_MAX_IT", 22 "DIVERGED_FNORM_NAN","DIVERGED_LINEAR_SOLVE","DIVERGED_FUNCTION_COUNT","DIVERGED_FUNCTION_DOMAIN", 23 "CONVERGED_ITERATING"," ","CONVERGED_FNORM_ABS","CONVERGED_FNORM_RELATIVE", 24 "CONVERGED_PNORM_RELATIVE","CONVERGED_ITS"," ","CONVERGED_TR_DELTA","SNESConvergedReason","",0}; 25 const char *const*SNESConvergedReasons = SNESConvergedReasons_Shifted + 10; 26 27 /* 28 This is used by SNESSetType() to make sure that at least one 29 SNESRegisterAll() is called. In general, if there is more than one 30 DLL then SNESRegisterAll() may be called several times. 31 */ 32 extern PetscBool SNESRegisterAllCalled; 33 34 #undef __FUNCT__ 35 #define __FUNCT__ "SNESRegisterAll" 36 /*@C 37 SNESRegisterAll - Registers all of the nonlinear solver methods in the SNES package. 38 39 Not Collective 40 41 Level: advanced 42 43 .keywords: SNES, register, all 44 45 .seealso: SNESRegisterDestroy() 46 @*/ 47 PetscErrorCode SNESRegisterAll(const char path[]) 48 { 49 PetscErrorCode ierr; 50 51 PetscFunctionBegin; 52 SNESRegisterAllCalled = PETSC_TRUE; 53 54 ierr = SNESRegisterDynamic(SNESLS, path,"SNESCreate_LS", SNESCreate_LS);CHKERRQ(ierr); 55 ierr = SNESRegisterDynamic(SNESTR, path,"SNESCreate_TR", SNESCreate_TR);CHKERRQ(ierr); 56 ierr = SNESRegisterDynamic(SNESTEST, path,"SNESCreate_Test", SNESCreate_Test);CHKERRQ(ierr); 57 ierr = SNESRegisterDynamic(SNESNRICHARDSON, path,"SNESCreate_NRichardson", SNESCreate_NRichardson);CHKERRQ(ierr); 58 ierr = SNESRegisterDynamic(SNESKSPONLY, path,"SNESCreate_KSPONLY", SNESCreate_KSPONLY);CHKERRQ(ierr); 59 ierr = SNESRegisterDynamic(SNESVIRS, path,"SNESCreate_VIRS", SNESCreate_VIRS);CHKERRQ(ierr); 60 ierr = SNESRegisterDynamic(SNESVISS, path,"SNESCreate_VISS", SNESCreate_VISS);CHKERRQ(ierr); 61 ierr = SNESRegisterDynamic(SNESNGMRES, path,"SNESCreate_NGMRES", SNESCreate_NGMRES);CHKERRQ(ierr); 62 ierr = SNESRegisterDynamic(SNESQN, path,"SNESCreate_QN", SNESCreate_QN);CHKERRQ(ierr); 63 ierr = SNESRegisterDynamic(SNESSHELL, path,"SNESCreate_Shell", SNESCreate_Shell);CHKERRQ(ierr); 64 ierr = SNESRegisterDynamic(SNESGS, path,"SNESCreate_GS", SNESCreate_GS);CHKERRQ(ierr); 65 ierr = SNESRegisterDynamic(SNESSORQN, path,"SNESCreate_SORQN", SNESCreate_SORQN);CHKERRQ(ierr); 66 ierr = SNESRegisterDynamic(SNESNCG, path,"SNESCreate_NCG", SNESCreate_NCG);CHKERRQ(ierr); 67 ierr = SNESRegisterDynamic(SNESFAS, path,"SNESCreate_FAS", SNESCreate_FAS);CHKERRQ(ierr); 68 PetscFunctionReturn(0); 69 } 70