#define TAOSOLVER_DLL

#include "tao-private/taosolver_impl.h" /*I "taosolver.h" I*/


PETSC_EXTERN PetscErrorCode TaoCreate_LMVM(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_NLS(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_NTR(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_NTL(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_NM(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_CG(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_TRON(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_OWLQN(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_BMRM(TaoSolver);

PETSC_EXTERN PetscErrorCode TaoCreate_BLMVM(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_GPCG(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_BQPIP(TaoSolver);

PETSC_EXTERN PetscErrorCode TaoCreate_POUNDERS(TaoSolver);

PETSC_EXTERN PetscErrorCode TaoCreate_FD(TaoSolver);

PETSC_EXTERN PetscErrorCode TaoCreate_LCL(TaoSolver);

PETSC_EXTERN PetscErrorCode TaoCreate_SSILS(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_SSFLS(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_ASILS(TaoSolver);
PETSC_EXTERN PetscErrorCode TaoCreate_ASFLS(TaoSolver);

PETSC_EXTERN PetscErrorCode TaoCreate_IPM(TaoSolver);

/* 
   Offset the convergence reasons so negative number represent diverged and
   positive represent converged.
*/
const char *TaoSolverTerminationReasons_Shifted[] = {
    "DIVERGED_USER",
    "DIVERGED_TR_REDUCTION",
    "DIVERGED_LS_FAILURE",
    "DIVERGED_MAXFCN",
    "DIVERGED_NAN",
    "DIVERGED_MAXITS",
    "DIVERGED_FUNCTION_DOMAIN",
 
    "CONTINUE_ITERATING",
    
    "CONVERGED_FATOL",
    "CONVERGED_FRTOL",
    "CONVERGED_GATOL",
    "CONVERGED_GRTOL",
    "CONVERGED_GTTOL",
    "CONVERGED_STEPTOL",
    "CONVERGED_MINF",
    "CONVERGED_USER" };
const char **TaoSolverTerminationReasons = TaoSolverTerminationReasons_Shifted + 7;

						   


extern PetscBool TaoSolverRegisterAllCalled;

#undef __FUNCT__
#define __FUNCT__ "TaoSolverRegisterAll"
/*@C
  TaoSolverRegisterAll - Registers all of the minimization methods in the TAO
  package.

  Not Collective

  Level: developer

.seealso TaoSolverRegister(), TaoSolverRegisterDestroy()
@*/
PetscErrorCode TaoSolverRegisterAll()
{
  PetscErrorCode ierr;
  
  PetscFunctionBegin;
  TaoSolverRegisterAllCalled = PETSC_TRUE;
  
  ierr = TaoSolverRegister("tao_lmvm",TaoCreate_LMVM); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_nls",TaoCreate_NLS); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_ntr",TaoCreate_NTR); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_ntl",TaoCreate_NTL); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_cg",TaoCreate_CG); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_tron",TaoCreate_TRON); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_owlqn",TaoCreate_OWLQN); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_bmrm",TaoCreate_BMRM); CHKERRQ(ierr);

  ierr = TaoSolverRegister("tao_blmvm",TaoCreate_BLMVM); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_bqpip",TaoCreate_BQPIP); CHKERRQ(ierr);

  ierr = TaoSolverRegister("tao_gpcg",TaoCreate_GPCG); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_nm",TaoCreate_NM); CHKERRQ(ierr);

  ierr = TaoSolverRegister("tao_pounders",TaoCreate_POUNDERS); CHKERRQ(ierr);



  ierr = TaoSolverRegister("tao_lcl",TaoCreate_LCL); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_ssils",TaoCreate_SSILS); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_ssfls",TaoCreate_SSFLS); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_asils",TaoCreate_ASILS); CHKERRQ(ierr);
  ierr = TaoSolverRegister("tao_asfls",TaoCreate_ASFLS); CHKERRQ(ierr);


  ierr = TaoSolverRegister("tao_ipm",TaoCreate_IPM); CHKERRQ(ierr);



  ierr = TaoSolverRegister("tao_fd_test",TaoCreate_FD); CHKERRQ(ierr);


  
  PetscFunctionReturn(0);
}
    

