xref: /petsc/include/petscoptions.h (revision c619b03e9a39856418a9e23c79aa5be44c20f181)
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
62c8e378dSBarry Smith #include <petscsys.h>
7*c619b03eSJed Brown #include <petscviewertypes.h>
83a3b2205SBarry Smith 
9014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsHasName(const char[],const char[],PetscBool *);
10014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetInt(const char[],const char [],PetscInt *,PetscBool *);
11014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetBool(const char[],const char [],PetscBool  *,PetscBool *);
12014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetReal(const char[],const char[],PetscReal *,PetscBool *);
13014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetScalar(const char[],const char[],PetscScalar *,PetscBool *);
14014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetIntArray(const char[],const char[],PetscInt[],PetscInt *,PetscBool *);
15014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetRealArray(const char[],const char[],PetscReal[],PetscInt *,PetscBool *);
16014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetBoolArray(const char[],const char[],PetscBool [],PetscInt *,PetscBool *);
17014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetString(const char[],const char[],char[],size_t,PetscBool *);
18014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetStringArray(const char[],const char[],char*[],PetscInt*,PetscBool *);
19014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetEList(const char[],const char[],const char*const*,PetscInt,PetscInt*,PetscBool *);
20014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetEnum(const char[],const char[],const char*const*,PetscEnum*,PetscBool *);
21014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsValidKey(const char[],PetscBool *);
223a3b2205SBarry Smith 
23014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsSetAlias(const char[],const char[]);
24014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsSetValue(const char[],const char[]);
25014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsClearValue(const char[]);
263a3b2205SBarry Smith 
27014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsAllUsed(PetscInt*);
28014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsUsed(const char *,PetscBool*);
29014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsLeft(void);
30014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsView(PetscViewer);
314b0e389bSBarry Smith 
32014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsCreate(void);
33014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsInsert(int*,char ***,const char[]);
34014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsInsertFile(MPI_Comm,const char[],PetscBool );
353bcbd388SSean Farley #if defined(PETSC_HAVE_YAML)
36014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsInsertFile_YAML(MPI_Comm,const char[],PetscBool);
373bcbd388SSean Farley #endif
38014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsInsertString(const char[]);
39014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsDestroy(void);
40014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsClear(void);
41014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsPrefixPush(const char[]);
42014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsPrefixPop(void);
435d0dffe5SBarry Smith 
44014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsReject(const char[],const char[]);
45014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetAll(char*[]);
465d0dffe5SBarry Smith 
47014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsGetenv(MPI_Comm,const char[],char[],size_t,PetscBool  *);
48014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsStringToInt(const char[],PetscInt*);
49014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsStringToReal(const char[],PetscReal*);
50014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsStringToBool(const char[],PetscBool*);
512e8a6d31SBarry Smith 
52014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsMonitorSet(PetscErrorCode (*)(const char[], const char[], void*), void *, PetscErrorCode (*)(void**));
53014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsMonitorCancel(void);
54014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsMonitorDefault(const char[], const char[], void *);
55081c24baSBoyana Norris 
56014dd563SJed Brown PETSC_EXTERN PetscBool PetscOptionsPublish;
57014dd563SJed Brown PETSC_EXTERN 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 
63f2ba6396SBarry Smith    Synopsis:
64f2ba6396SBarry Smith     #include "petscoptions.h"
65f2ba6396SBarry Smith     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
85c8e70145SBarry Smith $                    database updated updated with user changes; PetscOptionsGetInt() etc are also called
86c8e70145SBarry Smith $             = 1 : The PetscOptionsInt() etc again call the PetscOptionsGetInt() etc (possibly getting new values), in addition the help message and
87c8e70145SBarry Smith $                   default values are printed if -help was given.
88538aa990SBarry Smith $           When PetscOptionsObject.changedmethod is set this causes PetscOptionsPublishCount to be reset to -2 (so in the next loop iteration it is -1)
89538aa990SBarry Smith $           and the whole process is repeated. This is to handle when, for example, the KSPType is changed thus changing the list of
90538aa990SBarry Smith $           options available so they need to be redisplayed so the user can change the. Chaning PetscOptionsObjects.changedmethod is never
91538aa990SBarry Smith $           currently set.
92aee2cecaSBarry Smith 
93aee2cecaSBarry Smith 
9430de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(),
95acfcf0e5SJed Brown           PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsBool()
96acfcf0e5SJed Brown           PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsBool(),
9730de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
9830de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
99acfcf0e5SJed Brown           PetscOptionsBoolGroupBegin(), PetscOptionsBoolGroup(), PetscOptionsBoolGroupEnd(),
1005fefd1ebSJed Brown           PetscOptionsList(), PetscOptionsEList(), PetscObjectOptionsBegin()
10130de9b25SBarry Smith 
10230de9b25SBarry Smith M*/
1033194b578SJed Brown #define    PetscOptionsBegin(comm,prefix,mess,sec) 0; do {\
104b0a32e0cSBarry Smith              for (PetscOptionsPublishCount=(PetscOptionsPublish?-1:1); PetscOptionsPublishCount<2; PetscOptionsPublishCount++) {\
1057c307921SBarry Smith              PetscErrorCode _5_ierr = PetscOptionsBegin_Private(comm,prefix,mess,sec);CHKERRQ(_5_ierr);
10630de9b25SBarry Smith 
1075fefd1ebSJed Brown /*MC
1085fefd1ebSJed Brown     PetscObjectOptionsBegin - Begins a set of queries on the options database that are related and should be
1095fefd1ebSJed Brown      displayed on the same window of a GUI that allows the user to set the options interactively.
1105fefd1ebSJed Brown 
111f2ba6396SBarry Smith    Synopsis:
112f2ba6396SBarry Smith     #include "petscoptions.h"
113f2ba6396SBarry Smith     PetscErrorCode PetscObjectOptionsBegin(PetscObject obj)
1145fefd1ebSJed Brown 
1155fefd1ebSJed Brown     Collective on PetscObject
1165fefd1ebSJed Brown 
1175fefd1ebSJed Brown   Input Parameters:
1185fefd1ebSJed Brown .   obj - object to set options for
1195fefd1ebSJed Brown 
1205fefd1ebSJed Brown   Level: intermediate
1215fefd1ebSJed Brown 
1225fefd1ebSJed Brown   Notes: Needs to be ended by a call the PetscOptionsEnd()
1235fefd1ebSJed Brown          Can add subheadings with PetscOptionsHead()
1245fefd1ebSJed Brown 
1255fefd1ebSJed Brown .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(),
1265fefd1ebSJed Brown           PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsBool()
1275fefd1ebSJed Brown           PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsBool(),
1285fefd1ebSJed Brown           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
1295fefd1ebSJed Brown           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
1305fefd1ebSJed Brown           PetscOptionsBoolGroupBegin(), PetscOptionsBoolGroup(), PetscOptionsBoolGroupEnd(),
1315fefd1ebSJed Brown           PetscOptionsList(), PetscOptionsEList()
1325fefd1ebSJed Brown 
1335fefd1ebSJed Brown M*/
1343194b578SJed Brown #define PetscObjectOptionsBegin(obj) 0; do {                            \
1353194b578SJed Brown   for (PetscOptionsPublishCount=(PetscOptionsPublish?-1:1); PetscOptionsPublishCount<2; PetscOptionsPublishCount++) { \
1363194b578SJed Brown   PetscErrorCode _5_ierr = PetscObjectOptionsBegin_Private(obj);CHKERRQ(_5_ierr);
1373194b578SJed Brown 
13830de9b25SBarry Smith /*MC
13930de9b25SBarry Smith     PetscOptionsEnd - Ends a set of queries on the options database that are related and should be
14030de9b25SBarry Smith      displayed on the same window of a GUI that allows the user to set the options interactively.
14130de9b25SBarry Smith 
14230de9b25SBarry Smith     Collective on the MPI_Comm used in PetscOptionsBegin()
14330de9b25SBarry Smith 
144f2ba6396SBarry Smith    Synopsis:
145f2ba6396SBarry Smith      #include "petscoptions.h"
146f2ba6396SBarry Smith      PetscErrorCode PetscOptionsEnd(void)
14730de9b25SBarry Smith 
14830de9b25SBarry Smith   Level: intermediate
14930de9b25SBarry Smith 
15030de9b25SBarry Smith   Notes: Needs to be preceded by a call to PetscOptionsBegin()
15130de9b25SBarry Smith 
15230de9b25SBarry Smith .seealso: PetscOptionsGetReal(), PetscOptionsHasName(), PetscOptionsGetString(), PetscOptionsGetInt(),
153acfcf0e5SJed Brown           PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsBool()
154acfcf0e5SJed Brown           PetscOptionsInt(), PetscOptionsString(), PetscOptionsReal(), PetscOptionsBool(),
15530de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
15630de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
157acfcf0e5SJed Brown           PetscOptionsBoolGroupBegin(), PetscOptionsBoolGroup(), PetscOptionsBoolGroupEnd(),
1585fefd1ebSJed Brown           PetscOptionsList(), PetscOptionsEList(), PetscObjectOptionsBegin()
15930de9b25SBarry Smith 
16030de9b25SBarry Smith M*/
1613194b578SJed Brown #define    PetscOptionsEnd() _5_ierr = PetscOptionsEnd_Private();CHKERRQ(_5_ierr);}} while (0)
16230de9b25SBarry Smith 
163014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsBegin_Private(MPI_Comm,const char[],const char[],const char[]);
164014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscObjectOptionsBegin_Private(PetscObject);
165014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsEnd_Private(void);
166014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsHead(const char[]);
16730de9b25SBarry Smith 
16830de9b25SBarry Smith /*MC
16930de9b25SBarry Smith      PetscOptionsTail - Ends a section of options begun with PetscOptionsHead()
17030de9b25SBarry Smith             See, for example, KSPSetFromOptions_GMRES().
17130de9b25SBarry Smith 
17230de9b25SBarry Smith    Collective on the communicator passed in PetscOptionsBegin()
17330de9b25SBarry Smith 
174f2ba6396SBarry Smith    Synopsis:
175f2ba6396SBarry Smith      #include "petscoptions.h"
176f2ba6396SBarry Smith      PetscErrorCode PetscOptionsTail(void)
17730de9b25SBarry Smith 
17830de9b25SBarry Smith   Level: intermediate
17930de9b25SBarry Smith 
18030de9b25SBarry Smith    Notes: Must be between a PetscOptionsBegin() and a PetscOptionsEnd()
18130de9b25SBarry Smith 
18230de9b25SBarry Smith           Must be preceded by a call to PetscOptionsHead() in the same function.
18330de9b25SBarry Smith 
184b52f573bSBarry Smith           This needs to be used only if the code below PetscOptionsTail() can be run ONLY once.
185b52f573bSBarry Smith       See, for example, PCSetFromOptions_Composite(). This is a return(0) in it for early exit
186b52f573bSBarry Smith       from the function.
187b52f573bSBarry Smith 
188b52f573bSBarry Smith           This is only for use with the PETSc options GUI; which does not currently exist.
189b52f573bSBarry Smith 
19030de9b25SBarry Smith    Concepts: options database^subheading
19130de9b25SBarry Smith 
19230de9b25SBarry Smith .seealso: PetscOptionsGetInt(), PetscOptionsGetReal(),
193acfcf0e5SJed Brown            PetscOptionsHasName(), PetscOptionsGetIntArray(), PetscOptionsGetRealArray(), PetscOptionsBool(),
19430de9b25SBarry Smith           PetscOptionsName(), PetscOptionsBegin(), PetscOptionsEnd(), PetscOptionsHead(),
19530de9b25SBarry Smith           PetscOptionsStringArray(),PetscOptionsRealArray(), PetscOptionsScalar(),
196acfcf0e5SJed Brown           PetscOptionsBoolGroupBegin(), PetscOptionsBoolGroup(), PetscOptionsBoolGroupEnd(),
1979dcbbd2bSBarry Smith           PetscOptionsList(), PetscOptionsEList(), PetscOptionsEnum()
19830de9b25SBarry Smith M*/
199b0a32e0cSBarry Smith #define    PetscOptionsTail() 0; {if (PetscOptionsPublishCount != 1) PetscFunctionReturn(0);}
200186905e3SBarry Smith 
201014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsEnum(const char[],const char[],const char[],const char *const*,PetscEnum,PetscEnum*,PetscBool *);
202014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsInt(const char[],const char[],const char[],PetscInt,PetscInt*,PetscBool *);
203014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsReal(const char[],const char[],const char[],PetscReal,PetscReal*,PetscBool *);
204014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsScalar(const char[],const char[],const char[],PetscScalar,PetscScalar*,PetscBool *);
205014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsName(const char[],const char[],const char[],PetscBool *);
206014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsString(const char[],const char[],const char[],const char[],char*,size_t,PetscBool *);
207014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsBool(const char[],const char[],const char[],PetscBool ,PetscBool *,PetscBool *);
208014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsBoolGroupBegin(const char[],const char[],const char[],PetscBool *);
209014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsBoolGroup(const char[],const char[],const char[],PetscBool *);
210014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsBoolGroupEnd(const char[],const char[],const char[],PetscBool *);
211140e18c1SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsList(const char[],const char[],const char[],PetscFunctionList,const char[],char[],size_t,PetscBool *);
212014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsEList(const char[],const char[],const char[],const char*const*,PetscInt,const char[],PetscInt*,PetscBool *);
213014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsRealArray(const char[],const char[],const char[],PetscReal[],PetscInt*,PetscBool *);
214014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsIntArray(const char[],const char[],const char[],PetscInt[],PetscInt*,PetscBool *);
215014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsStringArray(const char[],const char[],const char[],char*[],PetscInt*,PetscBool *);
216014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsBoolArray(const char[],const char[],const char[],PetscBool [],PetscInt*,PetscBool *);
217cffb1e40SBarry Smith 
218e9fa29b7SSatish Balay 
219014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsSetFromOptions(void);
220014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscOptionsAMSDestroy(void);
221f8d0b74dSMatthew Knepley 
222e26ddf31SBarry Smith /*
223e26ddf31SBarry Smith     See manual page for PetscOptionsBegin()
224e26ddf31SBarry Smith */
2251ae3d29cSBarry Smith typedef enum {OPTION_INT,OPTION_LOGICAL,OPTION_REAL,OPTION_LIST,OPTION_STRING,OPTION_REAL_ARRAY,OPTION_HEAD,OPTION_INT_ARRAY,OPTION_ELIST,OPTION_LOGICAL_ARRAY,OPTION_STRING_ARRAY} PetscOptionType;
2266e655a9bSJed Brown typedef struct _n_PetscOptions* PetscOptions;
2276e655a9bSJed Brown struct _n_PetscOptions {
228f8d0b74dSMatthew Knepley   char              *option;
229f8d0b74dSMatthew Knepley   char              *text;
2303cc1e11dSBarry Smith   void              *data;         /* used to hold the default value and then any value it is changed to by GUI */
231140e18c1SBarry Smith   PetscFunctionList flist;         /* used for available values for PetscOptionsList() */
2321ae3d29cSBarry Smith   const char *const *list;        /* used for available values for PetscOptionsEList() */
2331ae3d29cSBarry Smith   char              nlist;         /* number of entries in list */
234f8d0b74dSMatthew Knepley   char              *man;
2353cc1e11dSBarry Smith   size_t            arraylength;   /* number of entries in data in the case that it is an array (of PetscInt etc) */
236ace3abfcSBarry Smith   PetscBool         set;           /* the user has changed this value in the GUI */
237e3ed6ec8SBarry Smith   PetscOptionType   type;
238f8d0b74dSMatthew Knepley   PetscOptions      next;
2391bc75a8dSBarry Smith   char              *pman;
24071f08665SBarry Smith   void              *edata;
241f8d0b74dSMatthew Knepley };
242f8d0b74dSMatthew Knepley 
243f8d0b74dSMatthew Knepley typedef struct {
244f8d0b74dSMatthew Knepley   PetscOptions     next;
2451bc75a8dSBarry Smith   char             *prefix,*pprefix;
246f8d0b74dSMatthew Knepley   char             *title;
247f8d0b74dSMatthew Knepley   MPI_Comm         comm;
248ace3abfcSBarry Smith   PetscBool        printhelp,changedmethod,alreadyprinted;
2493194b578SJed Brown   PetscObject      object;
250f8d0b74dSMatthew Knepley } PetscOptionsObjectType;
2513a3b2205SBarry Smith #endif
252