1 #define PETSCSNES_DLL 2 3 #include "private/snesimpl.h" /*I "petscsnes.h" I*/ 4 5 EXTERN_C_BEGIN 6 EXTERN PetscErrorCode PETSCSNES_DLLEXPORT SNESCreate_LS(SNES); 7 EXTERN PetscErrorCode PETSCSNES_DLLEXPORT SNESCreate_TR(SNES); 8 EXTERN PetscErrorCode PETSCSNES_DLLEXPORT SNESCreate_Test(SNES); 9 EXTERN PetscErrorCode PETSCSNES_DLLEXPORT SNESCreate_Picard(SNES); 10 EXTERN PetscErrorCode PETSCSNES_DLLEXPORT SNESCreate_KSPONLY(SNES); 11 EXTERN PetscErrorCode PETSCSNES_DLLEXPORT SNESCreate_LSVI(SNES); 12 EXTERN_C_END 13 14 const char *SNESConvergedReasons_Shifted[] = {" "," ","DIVERGED_LOCAL_MIN"," ","DIVERGED_LS_FAILURE","DIVERGED_MAX_IT", 15 "DIVERGED_FNORM_NAN","DIVERGED_LINEAR_SOLVE","DIVERGED_FUNCTION_COUNT","DIVERGED_FUNCTION_DOMAIN", 16 "CONVERGED_ITERATING"," ","CONVERGED_FNORM_ABS","CONVERGED_FNORM_RELATIVE", 17 "CONVERGED_PNORM_RELATIVE","CONVERGED_ITS"," ","CONVERGED_TR_DELTA","SNESConvergedReason","",0}; 18 const char **SNESConvergedReasons = SNESConvergedReasons_Shifted + 10; 19 20 /* 21 This is used by SNESSetType() to make sure that at least one 22 SNESRegisterAll() is called. In general, if there is more than one 23 DLL then SNESRegisterAll() may be called several times. 24 */ 25 extern PetscTruth SNESRegisterAllCalled; 26 27 #undef __FUNCT__ 28 #define __FUNCT__ "SNESRegisterAll" 29 /*@C 30 SNESRegisterAll - Registers all of the nonlinear solver methods in the SNES package. 31 32 Not Collective 33 34 Level: advanced 35 36 .keywords: SNES, register, all 37 38 .seealso: SNESRegisterDestroy() 39 @*/ 40 PetscErrorCode PETSCSNES_DLLEXPORT SNESRegisterAll(const char path[]) 41 { 42 PetscErrorCode ierr; 43 44 PetscFunctionBegin; 45 SNESRegisterAllCalled = PETSC_TRUE; 46 47 ierr = SNESRegisterDynamic(SNESLS, path,"SNESCreate_LS", SNESCreate_LS);CHKERRQ(ierr); 48 ierr = SNESRegisterDynamic(SNESTR, path,"SNESCreate_TR", SNESCreate_TR);CHKERRQ(ierr); 49 ierr = SNESRegisterDynamic(SNESTEST, path,"SNESCreate_Test", SNESCreate_Test);CHKERRQ(ierr); 50 ierr = SNESRegisterDynamic(SNESPICARD, path,"SNESCreate_Picard", SNESCreate_Picard);CHKERRQ(ierr); 51 ierr = SNESRegisterDynamic(SNESKSPONLY,path,"SNESCreate_KSPONLY",SNESCreate_KSPONLY);CHKERRQ(ierr); 52 ierr = SNESRegisterDynamic(SNESLSVI, path,"SNESCreate_LSVI", SNESCreate_LSVI);CHKERRQ(ierr); 53 54 PetscFunctionReturn(0); 55 } 56 57