1f26ada1bSBarry Smith /* 237f753daSBarry Smith Routines to determine options set in the options database. 3f26ada1bSBarry Smith */ 40a835dfdSSatish Balay #if !defined(__PETSCOPTIONS_H) 50a835dfdSSatish Balay #define __PETSCOPTIONS_H 63a3b2205SBarry Smith #include "petsc.h" 7e9fa29b7SSatish Balay PETSC_EXTERN_CXX_BEGIN 83a3b2205SBarry Smith 9ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsHasName(const char[],const char[],PetscTruth*); 10045ff3e0SBarry Smith PetscPolymorphicSubroutine(PetscOptionsHasName,(const char b[],PetscTruth *f),(PETSC_NULL,b,f)) 11ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetInt(const char[],const char [],PetscInt *,PetscTruth*); 12045ff3e0SBarry Smith PetscPolymorphicSubroutine(PetscOptionsGetInt,(const char b[],PetscInt *i,PetscTruth *f),(PETSC_NULL,b,i,f)) 134dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetTruth(const char[],const char [],PetscTruth *,PetscTruth*); 144dc4c822SBarry Smith PetscPolymorphicSubroutine(PetscOptionsGetTruth,(const char b[],PetscTruth *i,PetscTruth *f),(PETSC_NULL,b,i,f)) 15ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetReal(const char[],const char[],PetscReal *,PetscTruth*); 16045ff3e0SBarry Smith PetscPolymorphicSubroutine(PetscOptionsGetReal,(const char b[],PetscReal *i,PetscTruth *f),(PETSC_NULL,b,i,f)) 17ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetScalar(const char[],const char[],PetscScalar *,PetscTruth*); 18045ff3e0SBarry Smith PetscPolymorphicSubroutine(PetscOptionsGetScalar,(const char b[],PetscScalar i[],PetscTruth *f),(PETSC_NULL,b,i,f)) 19ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetIntArray(const char[],const char[],PetscInt[],PetscInt *,PetscTruth*); 20045ff3e0SBarry Smith PetscPolymorphicSubroutine(PetscOptionsGetIntArray,(const char b[],PetscInt i[],PetscInt *ii,PetscTruth *f),(PETSC_NULL,b,i,ii,f)) 21ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetRealArray(const char[],const char[],PetscReal[],PetscInt *,PetscTruth*); 22045ff3e0SBarry Smith PetscPolymorphicSubroutine(PetscOptionsGetRealArray,(const char b[],PetscReal i[],PetscInt *ii,PetscTruth *f),(PETSC_NULL,b,i,ii,f)) 23ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetString(const char[],const char[],char[],size_t,PetscTruth*); 24045ff3e0SBarry Smith PetscPolymorphicSubroutine(PetscOptionsGetString,(const char b[],char i[],size_t s,PetscTruth *f),(PETSC_NULL,b,i,s,f)) 25ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetStringArray(const char[],const char[],char*[],PetscInt*,PetscTruth*); 26045ff3e0SBarry Smith PetscPolymorphicSubroutine(PetscOptionsGetStringArray,(const char b[],char *i[],PetscInt *ii,PetscTruth *f),(PETSC_NULL,b,i,ii,f)) 279dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetEList(const char[],const char[],const char**,PetscInt,PetscInt*,PetscTruth*); 289dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetEnum(const char[],const char[],const char**,PetscEnum*,PetscTruth*); 293a3b2205SBarry Smith 30ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsSetAlias(const char[],const char[]); 31ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsSetValue(const char[],const char[]); 32ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsClearValue(const char[]); 333a3b2205SBarry Smith 34ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsAllUsed(int*); 35ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsLeft(void); 36ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsPrint(FILE *); 374b0e389bSBarry Smith 38ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsCreate(void); 39ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsInsert(int*,char ***,const char[]); 40ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsInsertFile(const char[]); 41ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsInsertString(const char[]); 42ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsDestroy(void); 435d0dffe5SBarry Smith 44ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsReject(const char[],const char[]); 45ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetAll(char*[]); 465d0dffe5SBarry Smith 47ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetenv(MPI_Comm,const char[],char[],size_t,PetscTruth *); 48ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsAtoi(const char[],PetscInt*); 49ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsAtod(const char[],PetscReal*); 502e8a6d31SBarry Smith 51a6570f20SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsMonitorSet(PetscErrorCode (*)(const char[], const char[], void*), void *, PetscErrorCode (*)(void*)); 5295abf9c0SSatish Balay EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsMonitorCancel(void); 53a6570f20SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsMonitorDefault(const char[], const char[], void *); 54081c24baSBoyana Norris 55ff73aad6SKris Buschelman extern PETSC_DLLEXPORT PetscTruth PetscOptionsPublish; 567c307921SBarry Smith extern PETSC_DLLEXPORT PetscInt PetscOptionsPublishCount; 5730de9b25SBarry Smith 5830de9b25SBarry Smith /*MC 5930de9b25SBarry Smith PetscOptionsBegin - Begins a set of queries on the options database that are related and should be 6030de9b25SBarry Smith displayed on the same window of a GUI that allows the user to set the options interactively. 6130de9b25SBarry Smith 62d360dc6fSBarry Smith Synopsis: PetscErrorCode PetscOptionsBegin(MPI_Comm comm,const char prefix[],const char title[],const char mansec[]) 6330de9b25SBarry Smith 6430de9b25SBarry Smith Collective on MPI_Comm 6530de9b25SBarry Smith 6630de9b25SBarry Smith Input Parameters: 6730de9b25SBarry Smith + comm - communicator that shares GUI 6830de9b25SBarry Smith . prefix - options prefix for all options displayed on window 6930de9b25SBarry Smith . title - short descriptive text, for example "Krylov Solver Options" 7030de9b25SBarry Smith - mansec - section of manual pages for options, for example KSP 7130de9b25SBarry Smith 7230de9b25SBarry Smith Level: intermediate 7330de9b25SBarry Smith 7430de9b25SBarry Smith Notes: Needs to be ended by a call the PetscOptionsEnd() 7530de9b25SBarry Smith 7630de9b25SBarry Smith Can add subheadings with PetscOptionsHead() 7730de9b25SBarry Smith 7830de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(), 794dc4c822SBarry Smith PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth() 804dc4c822SBarry Smith PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsTruth(), 8130de9b25SBarry Smith PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(), 8230de9b25SBarry Smith PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(), 834dc4c822SBarry Smith PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(), 8430de9b25SBarry Smith PetscOptionsList(), PetscOptionsEList() 8530de9b25SBarry Smith 8630de9b25SBarry Smith M*/ 87b0a32e0cSBarry Smith #define PetscOptionsBegin(comm,prefix,mess,sec) 0; {\ 88b0a32e0cSBarry Smith for (PetscOptionsPublishCount=(PetscOptionsPublish?-1:1); PetscOptionsPublishCount<2; PetscOptionsPublishCount++) {\ 897c307921SBarry Smith PetscErrorCode _5_ierr = PetscOptionsBegin_Private(comm,prefix,mess,sec);CHKERRQ(_5_ierr); 9030de9b25SBarry Smith 9130de9b25SBarry Smith /*MC 9230de9b25SBarry Smith PetscOptionsEnd - Ends a set of queries on the options database that are related and should be 9330de9b25SBarry Smith displayed on the same window of a GUI that allows the user to set the options interactively. 9430de9b25SBarry Smith 9530de9b25SBarry Smith Collective on the MPI_Comm used in PetscOptionsBegin() 9630de9b25SBarry Smith 97d360dc6fSBarry Smith Synopsis: PetscErrorCode PetscOptionsEnd(void) 9830de9b25SBarry Smith 9930de9b25SBarry Smith Level: intermediate 10030de9b25SBarry Smith 10130de9b25SBarry Smith Notes: Needs to be preceded by a call to PetscOptionsBegin() 10230de9b25SBarry Smith 10330de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(), 1044dc4c822SBarry Smith PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth() 1054dc4c822SBarry Smith PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsTruth(), 10630de9b25SBarry Smith PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(), 10730de9b25SBarry Smith PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(), 1084dc4c822SBarry Smith PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(), 10930de9b25SBarry Smith PetscOptionsList(), PetscOptionsEList() 11030de9b25SBarry Smith 11130de9b25SBarry Smith M*/ 112ef66eb69SBarry Smith #define PetscOptionsEnd() _5_ierr = PetscOptionsEnd_Private();CHKERRQ(_5_ierr);}} 11330de9b25SBarry Smith 114ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsBegin_Private(MPI_Comm,const char[],const char[],const char[]); 115ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEnd_Private(void); 116ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsHead(const char[]); 11730de9b25SBarry Smith 11830de9b25SBarry Smith /*MC 11930de9b25SBarry Smith PetscOptionsTail - Ends a section of options begun with PetscOptionsHead() 12030de9b25SBarry Smith See, for example, KSPSetFromOptions_GMRES(). 12130de9b25SBarry Smith 12230de9b25SBarry Smith Collective on the communicator passed in PetscOptionsBegin() 12330de9b25SBarry Smith 124d360dc6fSBarry Smith Synopsis: PetscErrorCode PetscOptionsTail(void) 12530de9b25SBarry Smith 12630de9b25SBarry Smith Level: intermediate 12730de9b25SBarry Smith 12830de9b25SBarry Smith Notes: Must be between a PetscOptionsBegin() and a PetscOptionsEnd() 12930de9b25SBarry Smith 13030de9b25SBarry Smith Must be preceded by a call to PetscOptionsHead() in the same function. 13130de9b25SBarry Smith 132b52f573bSBarry Smith This needs to be used only if the code below PetscOptionsTail() can be run ONLY once. 133b52f573bSBarry Smith See, for example, PCSetFromOptions_Composite(). This is a return(0) in it for early exit 134b52f573bSBarry Smith from the function. 135b52f573bSBarry Smith 136b52f573bSBarry Smith This is only for use with the PETSc options GUI; which does not currently exist. 137b52f573bSBarry Smith 13830de9b25SBarry Smith Concepts: options database^subheading 13930de9b25SBarry Smith 14030de9b25SBarry Smith .seealso: PetscOptionsGetInt(), PetscOptionsGetReal(), 1414dc4c822SBarry Smith PetscOptionsHasName(), PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth(), 14230de9b25SBarry Smith PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(), 14330de9b25SBarry Smith PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(), 1444dc4c822SBarry Smith PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(), 1459dcbbd2bSBarry Smith PetscOptionsList(), PetscOptionsEList(), PetscOptionsEnum() 14630de9b25SBarry Smith M*/ 147b0a32e0cSBarry Smith #define PetscOptionsTail() 0; {if (PetscOptionsPublishCount != 1) PetscFunctionReturn(0);} 148186905e3SBarry Smith 1499dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEnum(const char[],const char[],const char[],const char **,PetscEnum,PetscEnum*,PetscTruth*); 150ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsInt(const char[],const char[],const char[],PetscInt,PetscInt*,PetscTruth*); 151ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsReal(const char[],const char[],const char[],PetscReal,PetscReal*,PetscTruth*); 152ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsScalar(const char[],const char[],const char[],PetscScalar,PetscScalar*,PetscTruth*); 153ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsName(const char[],const char[],const char[],PetscTruth*); 154ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsString(const char[],const char[],const char[],const char[],char*,size_t,PetscTruth*); 1554dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruth(const char[],const char[],const char[],PetscTruth,PetscTruth*,PetscTruth*); 1564dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroupBegin(const char[],const char[],const char[],PetscTruth*); 1574dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroup(const char[],const char[],const char[],PetscTruth*); 1584dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroupEnd(const char[],const char[],const char[],PetscTruth*); 159ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsList(const char[],const char[],const char[],PetscFList,const char[],char[],PetscInt,PetscTruth*); 1609dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEList(const char[],const char[],const char[],const char**,PetscInt,const char[],PetscInt*,PetscTruth*); 161ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsRealArray(const char[],const char[],const char[],PetscReal[],PetscInt*,PetscTruth*); 162ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsIntArray(const char[],const char[],const char[],PetscInt[],PetscInt*,PetscTruth*); 163ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsStringArray(const char[],const char[],const char[],char*[],PetscInt*,PetscTruth*); 164e9fa29b7SSatish Balay 165ef6c6fedSBoyana Norris EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsSetFromOptions(); 166e9fa29b7SSatish Balay PETSC_EXTERN_CXX_END 167f8d0b74dSMatthew Knepley 168*e3ed6ec8SBarry Smith typedef enum {OPTION_INT,OPTION_LOGICAL,OPTION_REAL,OPTION_LIST,OPTION_STRING,OPTION_REAL_ARRAY,OPTION_HEAD} PetscOptionType; 169*e3ed6ec8SBarry Smith typedef struct _p_PetscOptions* PetscOptions; 170*e3ed6ec8SBarry Smith struct _p_PetscOptions { 171f8d0b74dSMatthew Knepley char *option; 172f8d0b74dSMatthew Knepley char *text; 173f8d0b74dSMatthew Knepley void *data; 174f8d0b74dSMatthew Knepley void *edata; 175f8d0b74dSMatthew Knepley char *man; 176f8d0b74dSMatthew Knepley int arraylength; 177f8d0b74dSMatthew Knepley PetscTruth set; 178*e3ed6ec8SBarry Smith PetscOptionType type; 179f8d0b74dSMatthew Knepley PetscOptions next; 180f8d0b74dSMatthew Knepley }; 181f8d0b74dSMatthew Knepley 182*e3ed6ec8SBarry Smith typedef struct _p_PetscOptionsHelp* PetscOptionsHelp; 183*e3ed6ec8SBarry Smith struct _p_PetscOptionsHelp { 184f8d0b74dSMatthew Knepley char *prefix; 185f8d0b74dSMatthew Knepley char *title; 186f8d0b74dSMatthew Knepley char *mansec; 187*e3ed6ec8SBarry Smith PetscOptionsHelp next; 188f8d0b74dSMatthew Knepley }; 189f8d0b74dSMatthew Knepley 190f8d0b74dSMatthew Knepley typedef struct { 191f8d0b74dSMatthew Knepley PetscOptions next; 192f8d0b74dSMatthew Knepley char *prefix,*mprefix; 193f8d0b74dSMatthew Knepley char *title; 194f8d0b74dSMatthew Knepley MPI_Comm comm; 195f8d0b74dSMatthew Knepley PetscTruth printhelp,changedmethod,alreadyprinted; 196*e3ed6ec8SBarry Smith PetscOptionsHelp help; 197f8d0b74dSMatthew Knepley } PetscOptionsObjectType; 1983a3b2205SBarry Smith #endif 199