xref: /petsc/include/petscoptions.h (revision aee2cecaeefd3e72544fa4788195f0bfc8b09c13)
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 
80*aee2cecaSBarry Smith   Developer notes: PetscOptionsPublish is set in PetscOptionsCheckInitial_Private() with -options_gui. When PetscOptionsPublish is set the
81*aee2cecaSBarry Smith $             loop between PetscOptionsBegin() and PetscOptionsEnd() is run THREE times with PetscOptionsPublishCount of values -1,0,1 otherwise
82*aee2cecaSBarry Smith $             the loop is run ONCE with a PetscOptionsPublishCount of 1.
83*aee2cecaSBarry Smith $             = -1 : The PetscOptionsInt() etc just call the PetscOptionsGetInt() etc
84*aee2cecaSBarry Smith $             = 0  : The GUI objects are created in PetscOptionsInt() etc and displayed in PetscOptionsEnd() and the options
85*aee2cecaSBarry Smith $                    database updated updated with user changes
86*aee2cecaSBarry Smith $             = 1 : The PetscOptionsInt() etc again call the PetscOptionsGetInt() etc (possibly getting new values)
87*aee2cecaSBarry Smith $
88*aee2cecaSBarry Smith 
89*aee2cecaSBarry Smith 
9030de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(),
914dc4c822SBarry Smith           PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth()
924dc4c822SBarry Smith           PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsTruth(),
9330de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
9430de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
954dc4c822SBarry Smith           PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(),
9630de9b25SBarry Smith           PetscOptionsList(), PetscOptionsEList()
9730de9b25SBarry Smith 
9830de9b25SBarry Smith M*/
99b0a32e0cSBarry Smith #define    PetscOptionsBegin(comm,prefix,mess,sec) 0; {\
100b0a32e0cSBarry Smith              for (PetscOptionsPublishCount=(PetscOptionsPublish?-1:1); PetscOptionsPublishCount<2; PetscOptionsPublishCount++) {\
1017c307921SBarry Smith              PetscErrorCode _5_ierr = PetscOptionsBegin_Private(comm,prefix,mess,sec);CHKERRQ(_5_ierr);
10230de9b25SBarry Smith 
10330de9b25SBarry Smith /*MC
10430de9b25SBarry Smith     PetscOptionsEnd - Ends a set of queries on the options database that are related and should be
10530de9b25SBarry Smith      displayed on the same window of a GUI that allows the user to set the options interactively.
10630de9b25SBarry Smith 
10730de9b25SBarry Smith     Collective on the MPI_Comm used in PetscOptionsBegin()
10830de9b25SBarry Smith 
109d360dc6fSBarry Smith    Synopsis: PetscErrorCode PetscOptionsEnd(void)
11030de9b25SBarry Smith 
11130de9b25SBarry Smith   Level: intermediate
11230de9b25SBarry Smith 
11330de9b25SBarry Smith   Notes: Needs to be preceded by a call to PetscOptionsBegin()
11430de9b25SBarry Smith 
11530de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(),
1164dc4c822SBarry Smith           PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth()
1174dc4c822SBarry Smith           PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsTruth(),
11830de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
11930de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
1204dc4c822SBarry Smith           PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(),
12130de9b25SBarry Smith           PetscOptionsList(), PetscOptionsEList()
12230de9b25SBarry Smith 
12330de9b25SBarry Smith M*/
124ef66eb69SBarry Smith #define    PetscOptionsEnd() _5_ierr = PetscOptionsEnd_Private();CHKERRQ(_5_ierr);}}
12530de9b25SBarry Smith 
126ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsBegin_Private(MPI_Comm,const char[],const char[],const char[]);
127ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEnd_Private(void);
128ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsHead(const char[]);
12930de9b25SBarry Smith 
13030de9b25SBarry Smith /*MC
13130de9b25SBarry Smith      PetscOptionsTail - Ends a section of options begun with PetscOptionsHead()
13230de9b25SBarry Smith             See, for example, KSPSetFromOptions_GMRES().
13330de9b25SBarry Smith 
13430de9b25SBarry Smith    Collective on the communicator passed in PetscOptionsBegin()
13530de9b25SBarry Smith 
136d360dc6fSBarry Smith    Synopsis: PetscErrorCode PetscOptionsTail(void)
13730de9b25SBarry Smith 
13830de9b25SBarry Smith   Level: intermediate
13930de9b25SBarry Smith 
14030de9b25SBarry Smith    Notes: Must be between a PetscOptionsBegin() and a PetscOptionsEnd()
14130de9b25SBarry Smith 
14230de9b25SBarry Smith           Must be preceded by a call to PetscOptionsHead() in the same function.
14330de9b25SBarry Smith 
144b52f573bSBarry Smith           This needs to be used only if the code below PetscOptionsTail() can be run ONLY once.
145b52f573bSBarry Smith       See, for example, PCSetFromOptions_Composite(). This is a return(0) in it for early exit
146b52f573bSBarry Smith       from the function.
147b52f573bSBarry Smith 
148b52f573bSBarry Smith           This is only for use with the PETSc options GUI; which does not currently exist.
149b52f573bSBarry Smith 
15030de9b25SBarry Smith    Concepts: options database^subheading
15130de9b25SBarry Smith 
15230de9b25SBarry Smith .seealso: PetscOptionsGetInt(), PetscOptionsGetReal(),
1534dc4c822SBarry Smith            PetscOptionsHasName(), PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth(),
15430de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
15530de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
1564dc4c822SBarry Smith           PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(),
1579dcbbd2bSBarry Smith           PetscOptionsList(), PetscOptionsEList(), PetscOptionsEnum()
15830de9b25SBarry Smith M*/
159b0a32e0cSBarry Smith #define    PetscOptionsTail() 0; {if (PetscOptionsPublishCount != 1) PetscFunctionReturn(0);}
160186905e3SBarry Smith 
1619dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEnum(const char[],const char[],const char[],const char **,PetscEnum,PetscEnum*,PetscTruth*);
162ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsInt(const char[],const char[],const char[],PetscInt,PetscInt*,PetscTruth*);
163ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsReal(const char[],const char[],const char[],PetscReal,PetscReal*,PetscTruth*);
164ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsScalar(const char[],const char[],const char[],PetscScalar,PetscScalar*,PetscTruth*);
165ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsName(const char[],const char[],const char[],PetscTruth*);
166ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsString(const char[],const char[],const char[],const char[],char*,size_t,PetscTruth*);
1674dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruth(const char[],const char[],const char[],PetscTruth,PetscTruth*,PetscTruth*);
1684dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroupBegin(const char[],const char[],const char[],PetscTruth*);
1694dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroup(const char[],const char[],const char[],PetscTruth*);
1704dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroupEnd(const char[],const char[],const char[],PetscTruth*);
171ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsList(const char[],const char[],const char[],PetscFList,const char[],char[],PetscInt,PetscTruth*);
1729dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEList(const char[],const char[],const char[],const char**,PetscInt,const char[],PetscInt*,PetscTruth*);
173ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsRealArray(const char[],const char[],const char[],PetscReal[],PetscInt*,PetscTruth*);
174ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsIntArray(const char[],const char[],const char[],PetscInt[],PetscInt*,PetscTruth*);
175ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsStringArray(const char[],const char[],const char[],char*[],PetscInt*,PetscTruth*);
176e2446a98SMatthew Knepley EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthArray(const char[],const char[],const char[],PetscTruth[],PetscInt*,PetscTruth*);
177e9fa29b7SSatish Balay 
178b0a8bb96SLisandro Dalcin EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsSetFromOptions(void);
179e9fa29b7SSatish Balay PETSC_EXTERN_CXX_END
180f8d0b74dSMatthew Knepley 
181e3ed6ec8SBarry Smith typedef enum {OPTION_INT,OPTION_LOGICAL,OPTION_REAL,OPTION_LIST,OPTION_STRING,OPTION_REAL_ARRAY,OPTION_HEAD} PetscOptionType;
182e3ed6ec8SBarry Smith typedef struct _p_PetscOptions* PetscOptions;
183e3ed6ec8SBarry Smith struct _p_PetscOptions {
184f8d0b74dSMatthew Knepley   char            *option;
185f8d0b74dSMatthew Knepley   char            *text;
186f8d0b74dSMatthew Knepley   void            *data;
187f8d0b74dSMatthew Knepley   void            *edata;
188f8d0b74dSMatthew Knepley   char            *man;
189f8d0b74dSMatthew Knepley   int             arraylength;
190f8d0b74dSMatthew Knepley   PetscTruth      set;
191e3ed6ec8SBarry Smith   PetscOptionType type;
192f8d0b74dSMatthew Knepley   PetscOptions    next;
193f8d0b74dSMatthew Knepley };
194f8d0b74dSMatthew Knepley 
195e3ed6ec8SBarry Smith typedef struct _p_PetscOptionsHelp* PetscOptionsHelp;
196e3ed6ec8SBarry Smith struct _p_PetscOptionsHelp {
197f8d0b74dSMatthew Knepley   char             *prefix;
198f8d0b74dSMatthew Knepley   char             *title;
199f8d0b74dSMatthew Knepley   char             *mansec;
200e3ed6ec8SBarry Smith   PetscOptionsHelp next;
201f8d0b74dSMatthew Knepley };
202f8d0b74dSMatthew Knepley 
203f8d0b74dSMatthew Knepley typedef struct {
204f8d0b74dSMatthew Knepley   PetscOptions     next;
205f8d0b74dSMatthew Knepley   char             *prefix,*mprefix;
206f8d0b74dSMatthew Knepley   char             *title;
207f8d0b74dSMatthew Knepley   MPI_Comm         comm;
208f8d0b74dSMatthew Knepley   PetscTruth       printhelp,changedmethod,alreadyprinted;
209e3ed6ec8SBarry Smith   PetscOptionsHelp help;
210f8d0b74dSMatthew Knepley } PetscOptionsObjectType;
2113a3b2205SBarry Smith #endif
212