xref: /petsc/include/petscoptions.h (revision 9b754dc9f0663e19d2ff8c43d2d8cda7771fd51a)
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[]);
40*9b754dc9SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT  PetscOptionsInsertFile(MPI_Comm,const char[],PetscTruth);
41ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT  PetscOptionsInsertString(const char[]);
42ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT  PetscOptionsDestroy(void);
43a542b6e8SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT  PetscOptionsClear(void);
445d0dffe5SBarry Smith 
45ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT  PetscOptionsReject(const char[],const char[]);
46ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT  PetscOptionsGetAll(char*[]);
475d0dffe5SBarry Smith 
48ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT  PetscOptionsGetenv(MPI_Comm,const char[],char[],size_t,PetscTruth *);
49ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT  PetscOptionsAtoi(const char[],PetscInt*);
50ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT  PetscOptionsAtod(const char[],PetscReal*);
512e8a6d31SBarry Smith 
52a6570f20SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsMonitorSet(PetscErrorCode (*)(const char[], const char[], void*), void *, PetscErrorCode (*)(void*));
5395abf9c0SSatish Balay EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsMonitorCancel(void);
54a6570f20SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsMonitorDefault(const char[], const char[], void *);
55081c24baSBoyana Norris 
56ff73aad6SKris Buschelman extern PETSC_DLLEXPORT PetscTruth PetscOptionsPublish;
577c307921SBarry Smith extern PETSC_DLLEXPORT PetscInt   PetscOptionsPublishCount;
5830de9b25SBarry Smith 
5930de9b25SBarry Smith /*MC
6030de9b25SBarry Smith     PetscOptionsBegin - Begins a set of queries on the options database that are related and should be
6130de9b25SBarry Smith      displayed on the same window of a GUI that allows the user to set the options interactively.
6230de9b25SBarry Smith 
63d360dc6fSBarry Smith    Synopsis: PetscErrorCode PetscOptionsBegin(MPI_Comm comm,const char prefix[],const char title[],const char mansec[])
6430de9b25SBarry Smith 
6530de9b25SBarry Smith     Collective on MPI_Comm
6630de9b25SBarry Smith 
6730de9b25SBarry Smith   Input Parameters:
6830de9b25SBarry Smith +   comm - communicator that shares GUI
6930de9b25SBarry Smith .   prefix - options prefix for all options displayed on window
7030de9b25SBarry Smith .   title - short descriptive text, for example "Krylov Solver Options"
7130de9b25SBarry Smith -   mansec - section of manual pages for options, for example KSP
7230de9b25SBarry Smith 
7330de9b25SBarry Smith   Level: intermediate
7430de9b25SBarry Smith 
7530de9b25SBarry Smith   Notes: Needs to be ended by a call the PetscOptionsEnd()
7630de9b25SBarry Smith 
7730de9b25SBarry Smith          Can add subheadings with PetscOptionsHead()
7830de9b25SBarry Smith 
7930de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(),
804dc4c822SBarry Smith           PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth()
814dc4c822SBarry Smith           PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsTruth(),
8230de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
8330de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
844dc4c822SBarry Smith           PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(),
8530de9b25SBarry Smith           PetscOptionsList(), PetscOptionsEList()
8630de9b25SBarry Smith 
8730de9b25SBarry Smith M*/
88b0a32e0cSBarry Smith #define    PetscOptionsBegin(comm,prefix,mess,sec) 0; {\
89b0a32e0cSBarry Smith              for (PetscOptionsPublishCount=(PetscOptionsPublish?-1:1); PetscOptionsPublishCount<2; PetscOptionsPublishCount++) {\
907c307921SBarry Smith              PetscErrorCode _5_ierr = PetscOptionsBegin_Private(comm,prefix,mess,sec);CHKERRQ(_5_ierr);
9130de9b25SBarry Smith 
9230de9b25SBarry Smith /*MC
9330de9b25SBarry Smith     PetscOptionsEnd - Ends a set of queries on the options database that are related and should be
9430de9b25SBarry Smith      displayed on the same window of a GUI that allows the user to set the options interactively.
9530de9b25SBarry Smith 
9630de9b25SBarry Smith     Collective on the MPI_Comm used in PetscOptionsBegin()
9730de9b25SBarry Smith 
98d360dc6fSBarry Smith    Synopsis: PetscErrorCode PetscOptionsEnd(void)
9930de9b25SBarry Smith 
10030de9b25SBarry Smith   Level: intermediate
10130de9b25SBarry Smith 
10230de9b25SBarry Smith   Notes: Needs to be preceded by a call to PetscOptionsBegin()
10330de9b25SBarry Smith 
10430de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(),
1054dc4c822SBarry Smith           PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth()
1064dc4c822SBarry Smith           PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsTruth(),
10730de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
10830de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
1094dc4c822SBarry Smith           PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(),
11030de9b25SBarry Smith           PetscOptionsList(), PetscOptionsEList()
11130de9b25SBarry Smith 
11230de9b25SBarry Smith M*/
113ef66eb69SBarry Smith #define    PetscOptionsEnd() _5_ierr = PetscOptionsEnd_Private();CHKERRQ(_5_ierr);}}
11430de9b25SBarry Smith 
115ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsBegin_Private(MPI_Comm,const char[],const char[],const char[]);
116ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEnd_Private(void);
117ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsHead(const char[]);
11830de9b25SBarry Smith 
11930de9b25SBarry Smith /*MC
12030de9b25SBarry Smith      PetscOptionsTail - Ends a section of options begun with PetscOptionsHead()
12130de9b25SBarry Smith             See, for example, KSPSetFromOptions_GMRES().
12230de9b25SBarry Smith 
12330de9b25SBarry Smith    Collective on the communicator passed in PetscOptionsBegin()
12430de9b25SBarry Smith 
125d360dc6fSBarry Smith    Synopsis: PetscErrorCode PetscOptionsTail(void)
12630de9b25SBarry Smith 
12730de9b25SBarry Smith   Level: intermediate
12830de9b25SBarry Smith 
12930de9b25SBarry Smith    Notes: Must be between a PetscOptionsBegin() and a PetscOptionsEnd()
13030de9b25SBarry Smith 
13130de9b25SBarry Smith           Must be preceded by a call to PetscOptionsHead() in the same function.
13230de9b25SBarry Smith 
133b52f573bSBarry Smith           This needs to be used only if the code below PetscOptionsTail() can be run ONLY once.
134b52f573bSBarry Smith       See, for example, PCSetFromOptions_Composite(). This is a return(0) in it for early exit
135b52f573bSBarry Smith       from the function.
136b52f573bSBarry Smith 
137b52f573bSBarry Smith           This is only for use with the PETSc options GUI; which does not currently exist.
138b52f573bSBarry Smith 
13930de9b25SBarry Smith    Concepts: options database^subheading
14030de9b25SBarry Smith 
14130de9b25SBarry Smith .seealso: PetscOptionsGetInt(), PetscOptionsGetReal(),
1424dc4c822SBarry Smith            PetscOptionsHasName(), PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsTruth(),
14330de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
14430de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
1454dc4c822SBarry Smith           PetscOptionsTruthGroupBegin(), PetscOptionsTruthGroup(), PetscOptionsTruthGroupEnd(),
1469dcbbd2bSBarry Smith           PetscOptionsList(), PetscOptionsEList(), PetscOptionsEnum()
14730de9b25SBarry Smith M*/
148b0a32e0cSBarry Smith #define    PetscOptionsTail() 0; {if (PetscOptionsPublishCount != 1) PetscFunctionReturn(0);}
149186905e3SBarry Smith 
1509dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEnum(const char[],const char[],const char[],const char **,PetscEnum,PetscEnum*,PetscTruth*);
151ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsInt(const char[],const char[],const char[],PetscInt,PetscInt*,PetscTruth*);
152ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsReal(const char[],const char[],const char[],PetscReal,PetscReal*,PetscTruth*);
153ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsScalar(const char[],const char[],const char[],PetscScalar,PetscScalar*,PetscTruth*);
154ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsName(const char[],const char[],const char[],PetscTruth*);
155ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsString(const char[],const char[],const char[],const char[],char*,size_t,PetscTruth*);
1564dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruth(const char[],const char[],const char[],PetscTruth,PetscTruth*,PetscTruth*);
1574dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroupBegin(const char[],const char[],const char[],PetscTruth*);
1584dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroup(const char[],const char[],const char[],PetscTruth*);
1594dc4c822SBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsTruthGroupEnd(const char[],const char[],const char[],PetscTruth*);
160ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsList(const char[],const char[],const char[],PetscFList,const char[],char[],PetscInt,PetscTruth*);
1619dcbbd2bSBarry Smith EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsEList(const char[],const char[],const char[],const char**,PetscInt,const char[],PetscInt*,PetscTruth*);
162ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsRealArray(const char[],const char[],const char[],PetscReal[],PetscInt*,PetscTruth*);
163ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsIntArray(const char[],const char[],const char[],PetscInt[],PetscInt*,PetscTruth*);
164ff73aad6SKris Buschelman EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsStringArray(const char[],const char[],const char[],char*[],PetscInt*,PetscTruth*);
165e9fa29b7SSatish Balay 
166b0a8bb96SLisandro Dalcin EXTERN PetscErrorCode PETSC_DLLEXPORT PetscOptionsSetFromOptions(void);
167e9fa29b7SSatish Balay PETSC_EXTERN_CXX_END
168f8d0b74dSMatthew Knepley 
169e3ed6ec8SBarry Smith typedef enum {OPTION_INT,OPTION_LOGICAL,OPTION_REAL,OPTION_LIST,OPTION_STRING,OPTION_REAL_ARRAY,OPTION_HEAD} PetscOptionType;
170e3ed6ec8SBarry Smith typedef struct _p_PetscOptions* PetscOptions;
171e3ed6ec8SBarry Smith struct _p_PetscOptions {
172f8d0b74dSMatthew Knepley   char            *option;
173f8d0b74dSMatthew Knepley   char            *text;
174f8d0b74dSMatthew Knepley   void            *data;
175f8d0b74dSMatthew Knepley   void            *edata;
176f8d0b74dSMatthew Knepley   char            *man;
177f8d0b74dSMatthew Knepley   int             arraylength;
178f8d0b74dSMatthew Knepley   PetscTruth      set;
179e3ed6ec8SBarry Smith   PetscOptionType type;
180f8d0b74dSMatthew Knepley   PetscOptions    next;
181f8d0b74dSMatthew Knepley };
182f8d0b74dSMatthew Knepley 
183e3ed6ec8SBarry Smith typedef struct _p_PetscOptionsHelp* PetscOptionsHelp;
184e3ed6ec8SBarry Smith struct _p_PetscOptionsHelp {
185f8d0b74dSMatthew Knepley   char             *prefix;
186f8d0b74dSMatthew Knepley   char             *title;
187f8d0b74dSMatthew Knepley   char             *mansec;
188e3ed6ec8SBarry Smith   PetscOptionsHelp next;
189f8d0b74dSMatthew Knepley };
190f8d0b74dSMatthew Knepley 
191f8d0b74dSMatthew Knepley typedef struct {
192f8d0b74dSMatthew Knepley   PetscOptions     next;
193f8d0b74dSMatthew Knepley   char             *prefix,*mprefix;
194f8d0b74dSMatthew Knepley   char             *title;
195f8d0b74dSMatthew Knepley   MPI_Comm         comm;
196f8d0b74dSMatthew Knepley   PetscTruth       printhelp,changedmethod,alreadyprinted;
197e3ed6ec8SBarry Smith   PetscOptionsHelp help;
198f8d0b74dSMatthew Knepley } PetscOptionsObjectType;
1993a3b2205SBarry Smith #endif
200