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)) 23e2446a98SMatthew Knepley EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetTruthArray(const char[],const char[],PetscTruth[],PetscInt *,PetscTruth*); 24e2446a98SMatthew Knepley PetscPolymorphicSubroutine(PetscOptionsGetTruthArray,(const char b[],PetscTruth i[],PetscInt *ii,PetscTruth *f),(PETSC_NULL,b,i,ii,f)) 25ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetString(const char[],const char[],char[],size_t,PetscTruth*); 26045ff3e0SBarry Smith PetscPolymorphicSubroutine(PetscOptionsGetString,(const char b[],char i[],size_t s,PetscTruth *f),(PETSC_NULL,b,i,s,f)) 27ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetStringArray(const char[],const char[],char*[],PetscInt*,PetscTruth*); 28045ff3e0SBarry Smith PetscPolymorphicSubroutine(PetscOptionsGetStringArray,(const char b[],char *i[],PetscInt *ii,PetscTruth *f),(PETSC_NULL,b,i,ii,f)) 299dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetEList(const char[],const char[],const char**,PetscInt,PetscInt*,PetscTruth*); 309dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetEnum(const char[],const char[],const char**,PetscEnum*,PetscTruth*); 313a3b2205SBarry Smith 32ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsSetAlias(const char[],const char[]); 33ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsSetValue(const char[],const char[]); 34ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsClearValue(const char[]); 353a3b2205SBarry Smith 36ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsAllUsed(int*); 37ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsLeft(void); 38ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsPrint(FILE *); 394b0e389bSBarry Smith 40ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsCreate(void); 41ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsInsert(int*,char ***,const char[]); 429b754dc9SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsInsertFile(MPI_Comm,const char[],PetscTruth); 43ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsInsertString(const char[]); 44ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsDestroy(void); 45a542b6e8SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsClear(void); 465d0dffe5SBarry Smith 47ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsReject(const char[],const char[]); 48ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetAll(char*[]); 495d0dffe5SBarry Smith 50ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsGetenv(MPI_Comm,const char[],char[],size_t,PetscTruth *); 51ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsAtoi(const char[],PetscInt*); 52ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsAtod(const char[],PetscReal*); 532e8a6d31SBarry Smith 54a6570f20SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsMonitorSet(PetscErrorCode (*)(const char[], const char[], void*), void *, PetscErrorCode (*)(void*)); 5595abf9c0SSatish Balay EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsMonitorCancel(void); 56a6570f20SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsMonitorDefault(const char[], const char[], void *); 57081c24baSBoyana Norris 58ff73aad6SKris Buschelman extern PETSC_DLLEXPORT PetscTruth PetscOptionsPublish; 597c307921SBarry Smith extern PETSC_DLLEXPORT PetscInt PetscOptionsPublishCount; 6030de9b25SBarry Smith 6130de9b25SBarry Smith /*MC 6230de9b25SBarry Smith PetscOptionsBegin - Begins a set of queries on the options database that are related and should be 6330de9b25SBarry Smith displayed on the same window of a GUI that allows the user to set the options interactively. 6430de9b25SBarry Smith 65d360dc6fSBarry Smith Synopsis: PetscErrorCode PetscOptionsBegin(MPI_Comm comm,const char prefix[],const char title[],const char mansec[]) 6630de9b25SBarry Smith 6730de9b25SBarry Smith Collective on MPI_Comm 6830de9b25SBarry Smith 6930de9b25SBarry Smith Input Parameters: 7030de9b25SBarry Smith + comm - communicator that shares GUI 7130de9b25SBarry Smith . prefix - options prefix for all options displayed on window 7230de9b25SBarry Smith . title - short descriptive text, for example "Krylov Solver Options" 7330de9b25SBarry Smith - mansec - section of manual pages for options, for example KSP 7430de9b25SBarry Smith 7530de9b25SBarry Smith Level: intermediate 7630de9b25SBarry Smith 7730de9b25SBarry Smith Notes: Needs to be ended by a call the PetscOptionsEnd() 7830de9b25SBarry Smith Can add subheadings with PetscOptionsHead() 7930de9b25SBarry Smith 80aee2cecaSBarry Smith Developer notes: PetscOptionsPublish is set in PetscOptionsCheckInitial_Private() with -options_gui. When PetscOptionsPublish is set the 81aee2cecaSBarry Smith $ loop between PetscOptionsBegin() and PetscOptionsEnd() is run THREE times with PetscOptionsPublishCount of values -1,0,1 otherwise 82aee2cecaSBarry Smith $ the loop is run ONCE with a PetscOptionsPublishCount of 1. 83aee2cecaSBarry Smith $ = -1 : The PetscOptionsInt() etc just call the PetscOptionsGetInt() etc 84aee2cecaSBarry Smith $ = 0 : The GUI objects are created in PetscOptionsInt() etc and displayed in PetscOptionsEnd() and the options 85*c8e70145SBarry Smith $ database updated updated with user changes; PetscOptionsGetInt() etc are also called 86*c8e70145SBarry Smith $ = 1 : The PetscOptionsInt() etc again call the PetscOptionsGetInt() etc (possibly getting new values), in addition the help message and 87*c8e70145SBarry Smith $ default values are printed if -help was given. 88aee2cecaSBarry Smith $ 89aee2cecaSBarry Smith 90aee2cecaSBarry Smith 9130de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(), 924dc4c822SBarry Smith PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth() 934dc4c822SBarry Smith PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsTruth(), 9430de9b25SBarry Smith PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(), 9530de9b25SBarry Smith PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(), 964dc4c822SBarry Smith PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(), 9730de9b25SBarry Smith PetscOptionsList(), PetscOptionsEList() 9830de9b25SBarry Smith 9930de9b25SBarry Smith M*/ 100b0a32e0cSBarry Smith #define PetscOptionsBegin(comm,prefix,mess,sec) 0; {\ 101b0a32e0cSBarry Smith for (PetscOptionsPublishCount=(PetscOptionsPublish?-1:1); PetscOptionsPublishCount<2; PetscOptionsPublishCount++) {\ 1027c307921SBarry Smith PetscErrorCode _5_ierr = PetscOptionsBegin_Private(comm,prefix,mess,sec);CHKERRQ(_5_ierr); 10330de9b25SBarry Smith 10430de9b25SBarry Smith /*MC 10530de9b25SBarry Smith PetscOptionsEnd - Ends a set of queries on the options database that are related and should be 10630de9b25SBarry Smith displayed on the same window of a GUI that allows the user to set the options interactively. 10730de9b25SBarry Smith 10830de9b25SBarry Smith Collective on the MPI_Comm used in PetscOptionsBegin() 10930de9b25SBarry Smith 110d360dc6fSBarry Smith Synopsis: PetscErrorCode PetscOptionsEnd(void) 11130de9b25SBarry Smith 11230de9b25SBarry Smith Level: intermediate 11330de9b25SBarry Smith 11430de9b25SBarry Smith Notes: Needs to be preceded by a call to PetscOptionsBegin() 11530de9b25SBarry Smith 11630de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(), 1174dc4c822SBarry Smith PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth() 1184dc4c822SBarry Smith PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsTruth(), 11930de9b25SBarry Smith PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(), 12030de9b25SBarry Smith PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(), 1214dc4c822SBarry Smith PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(), 12230de9b25SBarry Smith PetscOptionsList(), PetscOptionsEList() 12330de9b25SBarry Smith 12430de9b25SBarry Smith M*/ 125ef66eb69SBarry Smith #define PetscOptionsEnd() _5_ierr = PetscOptionsEnd_Private();CHKERRQ(_5_ierr);}} 12630de9b25SBarry Smith 127ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsBegin_Private(MPI_Comm,const char[],const char[],const char[]); 128ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEnd_Private(void); 129ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsHead(const char[]); 13030de9b25SBarry Smith 13130de9b25SBarry Smith /*MC 13230de9b25SBarry Smith PetscOptionsTail - Ends a section of options begun with PetscOptionsHead() 13330de9b25SBarry Smith See, for example, KSPSetFromOptions_GMRES(). 13430de9b25SBarry Smith 13530de9b25SBarry Smith Collective on the communicator passed in PetscOptionsBegin() 13630de9b25SBarry Smith 137d360dc6fSBarry Smith Synopsis: PetscErrorCode PetscOptionsTail(void) 13830de9b25SBarry Smith 13930de9b25SBarry Smith Level: intermediate 14030de9b25SBarry Smith 14130de9b25SBarry Smith Notes: Must be between a PetscOptionsBegin() and a PetscOptionsEnd() 14230de9b25SBarry Smith 14330de9b25SBarry Smith Must be preceded by a call to PetscOptionsHead() in the same function. 14430de9b25SBarry Smith 145b52f573bSBarry Smith This needs to be used only if the code below PetscOptionsTail() can be run ONLY once. 146b52f573bSBarry Smith See, for example, PCSetFromOptions_Composite(). This is a return(0) in it for early exit 147b52f573bSBarry Smith from the function. 148b52f573bSBarry Smith 149b52f573bSBarry Smith This is only for use with the PETSc options GUI; which does not currently exist. 150b52f573bSBarry Smith 15130de9b25SBarry Smith Concepts: options database^subheading 15230de9b25SBarry Smith 15330de9b25SBarry Smith .seealso: PetscOptionsGetInt(), PetscOptionsGetReal(), 1544dc4c822SBarry Smith PetscOptionsHasName(), PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth(), 15530de9b25SBarry Smith PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(), 15630de9b25SBarry Smith PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(), 1574dc4c822SBarry Smith PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(), 1589dcbbd2bSBarry Smith PetscOptionsList(), PetscOptionsEList(), PetscOptionsEnum() 15930de9b25SBarry Smith M*/ 160b0a32e0cSBarry Smith #define PetscOptionsTail() 0; {if (PetscOptionsPublishCount != 1) PetscFunctionReturn(0);} 161186905e3SBarry Smith 1629dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEnum(const char[],const char[],const char[],const char **,PetscEnum,PetscEnum*,PetscTruth*); 163ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsInt(const char[],const char[],const char[],PetscInt,PetscInt*,PetscTruth*); 164ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsReal(const char[],const char[],const char[],PetscReal,PetscReal*,PetscTruth*); 165ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsScalar(const char[],const char[],const char[],PetscScalar,PetscScalar*,PetscTruth*); 166ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsName(const char[],const char[],const char[],PetscTruth*); 167ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsString(const char[],const char[],const char[],const char[],char*,size_t,PetscTruth*); 1684dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruth(const char[],const char[],const char[],PetscTruth,PetscTruth*,PetscTruth*); 1694dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroupBegin(const char[],const char[],const char[],PetscTruth*); 1704dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroup(const char[],const char[],const char[],PetscTruth*); 1714dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroupEnd(const char[],const char[],const char[],PetscTruth*); 172ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsList(const char[],const char[],const char[],PetscFList,const char[],char[],PetscInt,PetscTruth*); 1739dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEList(const char[],const char[],const char[],const char**,PetscInt,const char[],PetscInt*,PetscTruth*); 174ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsRealArray(const char[],const char[],const char[],PetscReal[],PetscInt*,PetscTruth*); 175ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsIntArray(const char[],const char[],const char[],PetscInt[],PetscInt*,PetscTruth*); 176ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsStringArray(const char[],const char[],const char[],char*[],PetscInt*,PetscTruth*); 177e2446a98SMatthew Knepley EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthArray(const char[],const char[],const char[],PetscTruth[],PetscInt*,PetscTruth*); 178e9fa29b7SSatish Balay 179b0a8bb96SLisandro Dalcin EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsSetFromOptions(void); 180e9fa29b7SSatish Balay PETSC_EXTERN_CXX_END 181f8d0b74dSMatthew Knepley 182e3ed6ec8SBarry Smith typedef enum {OPTION_INT,OPTION_LOGICAL,OPTION_REAL,OPTION_LIST,OPTION_STRING,OPTION_REAL_ARRAY,OPTION_HEAD} PetscOptionType; 183e3ed6ec8SBarry Smith typedef struct _p_PetscOptions* PetscOptions; 184e3ed6ec8SBarry Smith struct _p_PetscOptions { 185f8d0b74dSMatthew Knepley char *option; 186f8d0b74dSMatthew Knepley char *text; 187f8d0b74dSMatthew Knepley void *data; 188f8d0b74dSMatthew Knepley void *edata; 189f8d0b74dSMatthew Knepley char *man; 190f8d0b74dSMatthew Knepley int arraylength; 191f8d0b74dSMatthew Knepley PetscTruth set; 192e3ed6ec8SBarry Smith PetscOptionType type; 193f8d0b74dSMatthew Knepley PetscOptions next; 194f8d0b74dSMatthew Knepley }; 195f8d0b74dSMatthew Knepley 196e3ed6ec8SBarry Smith typedef struct _p_PetscOptionsHelp* PetscOptionsHelp; 197e3ed6ec8SBarry Smith struct _p_PetscOptionsHelp { 198f8d0b74dSMatthew Knepley char *prefix; 199f8d0b74dSMatthew Knepley char *title; 200f8d0b74dSMatthew Knepley char *mansec; 201e3ed6ec8SBarry Smith PetscOptionsHelp next; 202f8d0b74dSMatthew Knepley }; 203f8d0b74dSMatthew Knepley 204f8d0b74dSMatthew Knepley typedef struct { 205f8d0b74dSMatthew Knepley PetscOptions next; 206f8d0b74dSMatthew Knepley char *prefix,*mprefix; 207f8d0b74dSMatthew Knepley char *title; 208f8d0b74dSMatthew Knepley MPI_Comm comm; 209f8d0b74dSMatthew Knepley PetscTruth printhelp,changedmethod,alreadyprinted; 210e3ed6ec8SBarry Smith PetscOptionsHelp help; 211f8d0b74dSMatthew Knepley } PetscOptionsObjectType; 2123a3b2205SBarry Smith #endif 213