xref: /petsc/include/petscviewer.h (revision 4bf303fab8706fca5c4c2515917737579b84f96a)
184cb2905SBarry Smith /*
2b0a32e0cSBarry Smith      PetscViewers are objects where other objects can be looked at or stored.
384cb2905SBarry Smith */
46524c165SJacob Faibussowitsch #ifndef PETSCVIEWER_H
526bd1501SBarry Smith #define PETSCVIEWER_H
6dfbe8321SBarry Smith 
76420c192SJed Brown #include <petscsys.h>
8c619b03eSJed Brown #include <petscviewertypes.h>
90954c5ccSStefano Zampini #include <petscdrawtypes.h>
10e9fa29b7SSatish Balay 
11ac09b921SBarry Smith /* SUBMANSEC = Viewer */
12ac09b921SBarry Smith 
13014dd563SJed Brown PETSC_EXTERN PetscClassId PETSC_VIEWER_CLASSID;
14e9fa29b7SSatish Balay 
1576bdecfbSBarry Smith /*J
1687497f52SBarry Smith     PetscViewerType - String with the name of a PETSc `PetscViewer` implementation
17b9617806SBarry Smith 
18b9617806SBarry Smith    Level: beginner
19b9617806SBarry Smith 
20d1f92df0SBarry Smith .seealso: [](sec_viewers), `PetscViewerSetType()`, `PetscViewer`, `PetscViewerRegister()`, `PetscViewerCreate()`
2176bdecfbSBarry Smith J*/
2219fd82e9SBarry Smith typedef const char *PetscViewerType;
232692d6eeSBarry Smith #define PETSCVIEWERSOCKET      "socket"
242692d6eeSBarry Smith #define PETSCVIEWERASCII       "ascii"
252692d6eeSBarry Smith #define PETSCVIEWERBINARY      "binary"
262692d6eeSBarry Smith #define PETSCVIEWERSTRING      "string"
272692d6eeSBarry Smith #define PETSCVIEWERDRAW        "draw"
282692d6eeSBarry Smith #define PETSCVIEWERVU          "vu"
292692d6eeSBarry Smith #define PETSCVIEWERMATHEMATICA "mathematica"
302692d6eeSBarry Smith #define PETSCVIEWERHDF5        "hdf5"
314061b8bfSJed Brown #define PETSCVIEWERVTK         "vtk"
322692d6eeSBarry Smith #define PETSCVIEWERMATLAB      "matlab"
33e04113cfSBarry Smith #define PETSCVIEWERSAWS        "saws"
348135c375SStefano Zampini #define PETSCVIEWERGLVIS       "glvis"
354c02969dSBarry Smith #define PETSCVIEWERADIOS       "adios"
361e50132fSMatthew G. Knepley #define PETSCVIEWEREXODUSII    "exodusii"
375f34f2dcSJed Brown #define PETSCVIEWERCGNS        "cgns"
3877ed5343SBarry Smith 
39140e18c1SBarry Smith PETSC_EXTERN PetscFunctionList PetscViewerList;
40607a6623SBarry Smith PETSC_EXTERN PetscErrorCode    PetscViewerInitializePackage(void);
41*4bf303faSJacob Faibussowitsch PETSC_EXTERN PetscErrorCode    PetscViewerFinalizePackage(void);
427b2a1423SBarry Smith 
43bdf89e91SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerRegister(const char[], PetscErrorCode (*)(PetscViewer));
4430de9b25SBarry Smith 
45014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerCreate(MPI_Comm, PetscViewer *);
46014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerSetFromOptions(PetscViewer);
47014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIIOpenWithFILE(MPI_Comm, FILE *, PetscViewer *);
487b2a1423SBarry Smith 
49014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIIOpen(MPI_Comm, const char[], PetscViewer *);
50014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIISetFILE(PetscViewer, FILE *);
51014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinaryOpen(MPI_Comm, const char[], PetscFileMode, PetscViewer *);
52a56f64adSBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerADIOSOpen(MPI_Comm, const char[], PetscFileMode, PetscViewer *);
53014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinaryGetFlowControl(PetscViewer, PetscInt *);
54014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinarySetFlowControl(PetscViewer, PetscInt);
55bc196f7cSDave May PETSC_EXTERN PetscErrorCode PetscViewerBinarySetUseMPIIO(PetscViewer, PetscBool);
56bc196f7cSDave May PETSC_EXTERN PetscErrorCode PetscViewerBinaryGetUseMPIIO(PetscViewer, PetscBool *);
570fc9d207SBarry Smith #if defined(PETSC_HAVE_MPIIO)
58014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinaryGetMPIIODescriptor(PetscViewer, MPI_File *);
59014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinaryGetMPIIOOffset(PetscViewer, MPI_Offset *);
60014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinaryAddMPIIOOffset(PetscViewer, MPI_Offset);
61951e3c8eSBarry Smith #endif
6239802e9eSBarry Smith 
63014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerSocketOpen(MPI_Comm, const char[], int, PetscViewer *);
6489d949e2SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerStringOpen(MPI_Comm, char[], size_t, PetscViewer *);
65014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDrawOpen(MPI_Comm, const char[], const char[], int, int, int, int, PetscViewer *);
66d1da0b69SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerDrawSetDrawType(PetscViewer, PetscDrawType);
671f49e1f7SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscViewerDrawGetDrawType(PetscViewer, PetscDrawType *);
68f55236e4SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscViewerDrawSetTitle(PetscViewer, const char[]);
69f55236e4SLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscViewerDrawGetTitle(PetscViewer, const char *[]);
700954c5ccSStefano Zampini PETSC_EXTERN PetscErrorCode PetscViewerDrawGetDraw(PetscViewer, PetscInt, PetscDraw *);
710954c5ccSStefano Zampini PETSC_EXTERN PetscErrorCode PetscViewerDrawBaseAdd(PetscViewer, PetscInt);
720954c5ccSStefano Zampini PETSC_EXTERN PetscErrorCode PetscViewerDrawBaseSet(PetscViewer, PetscInt);
730954c5ccSStefano Zampini PETSC_EXTERN PetscErrorCode PetscViewerDrawGetDrawLG(PetscViewer, PetscInt, PetscDrawLG *);
740954c5ccSStefano Zampini PETSC_EXTERN PetscErrorCode PetscViewerDrawGetDrawAxis(PetscViewer, PetscInt, PetscDrawAxis *);
750954c5ccSStefano Zampini 
76014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerMathematicaOpen(MPI_Comm, int, const char[], const char[], PetscViewer *);
77014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerSiloOpen(MPI_Comm, const char[], PetscViewer *);
78014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerMatlabOpen(MPI_Comm, const char[], PetscFileMode, PetscViewer *);
794b0e389bSBarry Smith 
808135c375SStefano Zampini /*E
813f423023SBarry Smith     PetscViewerGLVisType - indicates what type of `PETSCVIEWERGLVIS` viewer to use
828135c375SStefano Zampini 
833f423023SBarry Smith     Values:
843f423023SBarry Smith +   `PETSC_VIEWER_GLVIS_DUMP` - save the data to a file
853f423023SBarry Smith -   `PETSC_VIEWER_GLVIS_SOCKET` - communicate the data to another program via a socket
863f423023SBarry Smith 
8716a05f60SBarry Smith     Level: beginner
8816a05f60SBarry Smith 
893f423023SBarry Smith .seealso: [](sec_viewers), `PETSCVIEWERGLVIS`, `PetscViewerGLVisOpen()`
908135c375SStefano Zampini E*/
919371c9d4SSatish Balay typedef enum {
929371c9d4SSatish Balay   PETSC_VIEWER_GLVIS_DUMP,
939371c9d4SSatish Balay   PETSC_VIEWER_GLVIS_SOCKET
949371c9d4SSatish Balay } PetscViewerGLVisType;
958135c375SStefano Zampini PETSC_EXTERN PetscErrorCode PetscViewerGLVisOpen(MPI_Comm, PetscViewerGLVisType, const char *, PetscInt, PetscViewer *);
9677eacf09SStefano Zampini PETSC_EXTERN PetscErrorCode PetscViewerGLVisSetPrecision(PetscViewer, PetscInt);
978135c375SStefano Zampini PETSC_EXTERN PetscErrorCode PetscViewerGLVisSetSnapId(PetscViewer, PetscInt);
984cac2994SStefano Zampini PETSC_EXTERN PetscErrorCode PetscViewerGLVisSetFields(PetscViewer, PetscInt, const char *[], PetscInt[], PetscErrorCode (*)(PetscObject, PetscInt, PetscObject[], void *), PetscObject[], void *, PetscErrorCode (*)(void *));
998135c375SStefano Zampini 
10019fd82e9SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerGetType(PetscViewer, PetscViewerType *);
10119fd82e9SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerSetType(PetscViewer, PetscViewerType);
102014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDestroy(PetscViewer *);
1033f08860eSBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerGetSubViewer(PetscViewer, MPI_Comm, PetscViewer *);
1043f08860eSBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerRestoreSubViewer(PetscViewer, MPI_Comm, PetscViewer *);
105ae39576cSLois Curfman McInnes 
106014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerSetUp(PetscViewer);
107014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerView(PetscViewer, PetscViewer);
108fe2efc57SMark PETSC_EXTERN PetscErrorCode PetscViewerViewFromOptions(PetscViewer, PetscObject, const char[]);
109f69a0ea3SMatthew Knepley 
110014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerSetOptionsPrefix(PetscViewer, const char[]);
111014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerAppendOptionsPrefix(PetscViewer, const char[]);
112014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerGetOptionsPrefix(PetscViewer, const char *[]);
113090de74eSSatish Balay 
114e24fdd67SVaclav Hapla PETSC_EXTERN PetscErrorCode PetscViewerReadable(PetscViewer, PetscBool *);
115e24fdd67SVaclav Hapla PETSC_EXTERN PetscErrorCode PetscViewerWritable(PetscViewer, PetscBool *);
116d01f05b1SVaclav Hapla PETSC_EXTERN PetscErrorCode PetscViewerCheckReadable(PetscViewer);
117d01f05b1SVaclav Hapla PETSC_EXTERN PetscErrorCode PetscViewerCheckWritable(PetscViewer);
118e24fdd67SVaclav Hapla 
119edd03b47SJacob Faibussowitsch #define PETSC_VIEWER_ASCII_VTK_ATTR        PETSC_VIEWER_ASCII_VTK PETSC_DEPRECATED_ENUM(3, 14, 0, "PetscViewerVTKOpen() with XML (.vtr.vts.vtu) format", )
120edd03b47SJacob Faibussowitsch #define PETSC_VIEWER_ASCII_VTK_CELL_ATTR   PETSC_VIEWER_ASCII_VTK_CELL PETSC_DEPRECATED_ENUM(3, 14, 0, "PetscViewerVTKOpen() with XML (.vtr.vts.vtu) format", )
121edd03b47SJacob Faibussowitsch #define PETSC_VIEWER_ASCII_VTK_COORDS_ATTR PETSC_VIEWER_ASCII_VTK_COORDS PETSC_DEPRECATED_ENUM(3, 14, 0, "PetscViewerVTKOpen() with XML (.vtr .vts .vtu) format", )
122b9617806SBarry Smith /*E
123b9617806SBarry Smith     PetscViewerFormat - Way a viewer presents the object
124b9617806SBarry Smith 
1253f423023SBarry Smith    Values:
1263f423023SBarry Smith +    `PETSC_VIEWER_DEFAULT` - default format for the specific object being viewed
1273f423023SBarry Smith .    `PETSC_VIEWER_ASCII_MATLAB` - MATLAB format
1283f423023SBarry Smith .    `PETSC_VIEWER_ASCII_DENSE` - print matrix as dense
1293f423023SBarry Smith .    `PETSC_VIEWER_ASCII_IMPL` - implementation-specific format
1303f423023SBarry Smith       (which is in many cases the same as the default)
1313f423023SBarry Smith .    `PETSC_VIEWER_ASCII_INFO` - basic information about object
1323f423023SBarry Smith .    `PETSC_VIEWER_ASCII_INFO_DETAIL` - more detailed info
1333f423023SBarry Smith        about object
1343f423023SBarry Smith .    `PETSC_VIEWER_ASCII_COMMON` - identical output format for
1353f423023SBarry Smith        all objects of a particular type
1363f423023SBarry Smith .    `PETSC_VIEWER_ASCII_INDEX` - (for vectors) prints the vector
1373f423023SBarry Smith        element number next to each vector entry
1383f423023SBarry Smith .    `PETSC_VIEWER_ASCII_SYMMODU` - print parallel vectors without
1393f423023SBarry Smith        indicating the processor ranges
1403f423023SBarry Smith .    `PETSC_VIEWER_ASCII_VTK` - outputs the object to a VTK file (deprecated since v3.14)
1413f423023SBarry Smith .    `PETSC_VIEWER_NATIVE` - store the object to the binary
1423f423023SBarry Smith        file in its native format (for example, dense
1433f423023SBarry Smith        matrices are stored as dense), `DMDA` vectors are dumped directly to the
1443f423023SBarry Smith        file instead of being first put in the natural ordering
1453f423023SBarry Smith .    `PETSC_VIEWER_ASCII_LATEX` - output the data in LaTeX
1463f423023SBarry Smith .    `PETSC_VIEWER_BINARY_MATLAB` - output additional information that can be used to read the data into MATLAB
1473f423023SBarry Smith .    `PETSC_VIEWER_DRAW_BASIC` - views the vector with a simple 1d plot
1483f423023SBarry Smith .    `PETSC_VIEWER_DRAW_LG` - views the vector with a line graph
1493f423023SBarry Smith -    `PETSC_VIEWER_DRAW_CONTOUR` - views the vector with a contour plot
1503f423023SBarry Smith 
15116a05f60SBarry Smith    Level: beginner
15216a05f60SBarry Smith 
1533f423023SBarry Smith    Note:
1543f423023SBarry Smith    A variety of specialized formats also exist
1553f423023SBarry Smith 
156d1f92df0SBarry Smith .seealso: [](sec_viewers), `PetscViewer`, `PetscViewerType`, `PetscViewerPushFormat()`, `PetscViewerPopFormat()`
157b9617806SBarry Smith E*/
158fb9695e5SSatish Balay typedef enum {
159117016b1SBarry Smith   PETSC_VIEWER_DEFAULT,
160f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_MATLAB,
1614ebda54eSMatthew Knepley   PETSC_VIEWER_ASCII_MATHEMATICA,
162f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_IMPL,
163f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_INFO,
164456192e2SBarry Smith   PETSC_VIEWER_ASCII_INFO_DETAIL,
165f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_COMMON,
166f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_SYMMODU,
167f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_INDEX,
168f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_DENSE,
1693c215bfdSMatthew Knepley   PETSC_VIEWER_ASCII_MATRIXMARKET,
1708ec8862eSJed Brown   PETSC_VIEWER_ASCII_VTK_DEPRECATED,
1718ec8862eSJed Brown   PETSC_VIEWER_ASCII_VTK_ATTR = PETSC_VIEWER_ASCII_VTK_DEPRECATED,
1728ec8862eSJed Brown   PETSC_VIEWER_ASCII_VTK_CELL_DEPRECATED,
1738ec8862eSJed Brown   PETSC_VIEWER_ASCII_VTK_CELL_ATTR = PETSC_VIEWER_ASCII_VTK_CELL_DEPRECATED,
1748ec8862eSJed Brown   PETSC_VIEWER_ASCII_VTK_COORDS_DEPRECATED,
1758ec8862eSJed Brown   PETSC_VIEWER_ASCII_VTK_COORDS_ATTR = PETSC_VIEWER_ASCII_VTK_COORDS_DEPRECATED,
176493617b5SMatthew Knepley   PETSC_VIEWER_ASCII_PCICE,
177cfaaf4edSHong Zhang   PETSC_VIEWER_ASCII_PYTHON,
178cfaaf4edSHong Zhang   PETSC_VIEWER_ASCII_FACTOR_INFO,
17967ad5babSMatthew G Knepley   PETSC_VIEWER_ASCII_LATEX,
180bb1d7374SBarry Smith   PETSC_VIEWER_ASCII_XML,
181d0a29bd7SConnor Ward   PETSC_VIEWER_ASCII_FLAMEGRAPH,
1828135c375SStefano Zampini   PETSC_VIEWER_ASCII_GLVIS,
18338144912Sdeepblu2718   PETSC_VIEWER_ASCII_CSV,
184f3ef73ceSBarry Smith   PETSC_VIEWER_DRAW_BASIC,
185f3ef73ceSBarry Smith   PETSC_VIEWER_DRAW_LG,
186bb046f40SHong Zhang   PETSC_VIEWER_DRAW_LG_XRANGE,
187f3ef73ceSBarry Smith   PETSC_VIEWER_DRAW_CONTOUR,
188f3ef73ceSBarry Smith   PETSC_VIEWER_DRAW_PORTS,
1894061b8bfSJed Brown   PETSC_VIEWER_VTK_VTS,
190a13bc4e3SShao-Ching Huang   PETSC_VIEWER_VTK_VTR,
191b263465dSJed Brown   PETSC_VIEWER_VTK_VTU,
192a261c58fSBarry Smith   PETSC_VIEWER_BINARY_MATLAB,
193f3ef73ceSBarry Smith   PETSC_VIEWER_NATIVE,
1948aa4816bSVaclav Hapla   PETSC_VIEWER_HDF5_PETSC,
195ffe0aed0SMatthew G. Knepley   PETSC_VIEWER_HDF5_VIZ,
1968aa4816bSVaclav Hapla   PETSC_VIEWER_HDF5_XDMF,
197cbb4c999SVaclav Hapla   PETSC_VIEWER_HDF5_MAT,
198ef5fdb51SBarry Smith   PETSC_VIEWER_NOFORMAT,
199eafd5ff0SAlex Lindsay   PETSC_VIEWER_LOAD_BALANCE,
2007962402dSFande Kong   PETSC_VIEWER_FAILED,
2017962402dSFande Kong   PETSC_VIEWER_ALL
202cfaaf4edSHong Zhang } PetscViewerFormat;
203014dd563SJed Brown PETSC_EXTERN const char *const PetscViewerFormats[];
204090de74eSSatish Balay 
205edd03b47SJacob Faibussowitsch PETSC_EXTERN PETSC_DEPRECATED_FUNCTION(3, 7, 0, "PetscViewerPushFormat() / PetscViewerPopFormat()", ) PetscErrorCode PetscViewerSetFormat(PetscViewer, PetscViewerFormat);
206014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerPushFormat(PetscViewer, PetscViewerFormat);
207014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerPopFormat(PetscViewer);
208014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerGetFormat(PetscViewer, PetscViewerFormat *);
209014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerFlush(PetscViewer);
2104b0e389bSBarry Smith 
211eb55bdffSLawrence Mitchell PETSC_EXTERN PetscErrorCode PetscOptionsPushGetViewerOff(PetscBool);
212a30ec4eaSSatish Balay PETSC_EXTERN PetscErrorCode PetscOptionsPopGetViewerOff(void);
213eb55bdffSLawrence Mitchell PETSC_EXTERN PetscErrorCode PetscOptionsGetViewerOff(PetscBool *);
21416413a6aSBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsGetViewer(MPI_Comm, PetscOptions, const char[], const char[], PetscViewer *, PetscViewerFormat *, PetscBool *);
21509222b14SToby Isaac PETSC_EXTERN PetscErrorCode PetscOptionsGetViewers(MPI_Comm, PetscOptions, const char[], const char[], PetscInt *, PetscViewer *, PetscViewerFormat *, PetscBool *);
216e83a5d19SLisandro Dalcin #define PetscOptionsViewer(a, b, c, d, e, f) PetscOptionsViewer_Private(PetscOptionsObject, a, b, c, d, e, f)
2174416b707SBarry Smith PETSC_EXTERN PetscErrorCode PetscOptionsViewer_Private(PetscOptionItems *, const char[], const char[], const char[], PetscViewer *, PetscViewerFormat *, PetscBool *);
2182bf49c77SBarry Smith 
2199371c9d4SSatish Balay typedef struct {
2209371c9d4SSatish Balay   PetscViewer       viewer;
2219371c9d4SSatish Balay   PetscViewerFormat format;
2229371c9d4SSatish Balay   PetscDrawLG       lg;
2239812b6beSJed Brown   PetscInt          view_interval;
2249371c9d4SSatish Balay   void             *data;
2259371c9d4SSatish Balay } PetscViewerAndFormat;
226d7cbc13eSBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerAndFormatCreate(PetscViewer, PetscViewerFormat, PetscViewerAndFormat **);
227fe01d993SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerAndFormatDestroy(PetscViewerAndFormat **);
228fe01d993SBarry Smith 
22977ed5343SBarry Smith /*
23077ed5343SBarry Smith    Operations explicit to a particular class of viewers
23177ed5343SBarry Smith */
232ed5c6e3eSMatthew Knepley 
233014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIIGetPointer(PetscViewer, FILE **);
234014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerFileGetMode(PetscViewer, PetscFileMode *);
235014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerFileSetMode(PetscViewer, PetscFileMode);
236060da220SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PetscViewerRead(PetscViewer, void *, PetscInt, PetscInt *, PetscDataType);
2373ca90d2dSJacob Faibussowitsch PETSC_EXTERN PetscErrorCode PetscViewerASCIIPrintf(PetscViewer, const char[], ...) PETSC_ATTRIBUTE_FORMAT(2, 3);
2383ca90d2dSJacob Faibussowitsch PETSC_EXTERN PetscErrorCode PetscViewerASCIISynchronizedPrintf(PetscViewer, const char[], ...) PETSC_ATTRIBUTE_FORMAT(2, 3);
2391575c14dSBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerASCIIPushSynchronized(PetscViewer);
2401575c14dSBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerASCIIPopSynchronized(PetscViewer);
241014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIIPushTab(PetscViewer);
242014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIIPopTab(PetscViewer);
243014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIIUseTabs(PetscViewer, PetscBool);
244014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIISetTab(PetscViewer, PetscInt);
245014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIIGetTab(PetscViewer, PetscInt *);
246014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIIAddTab(PetscViewer, PetscInt);
247014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIISubtractTab(PetscViewer, PetscInt);
248060da220SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PetscViewerASCIIRead(PetscViewer, void *, PetscInt, PetscInt *, PetscDataType);
249014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinaryGetDescriptor(PetscViewer, int *);
250014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinaryGetInfoPointer(PetscViewer, FILE **);
251060da220SMatthew G. Knepley PETSC_EXTERN PetscErrorCode PetscViewerBinaryRead(PetscViewer, void *, PetscInt, PetscInt *, PetscDataType);
252f253e43cSLisandro Dalcin PETSC_EXTERN PetscErrorCode PetscViewerBinaryWrite(PetscViewer, const void *, PetscInt, PetscDataType);
25338b83642SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerBinaryReadAll(PetscViewer, void *, PetscInt, PetscInt64, PetscInt64, PetscDataType);
25438b83642SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerBinaryWriteAll(PetscViewer, const void *, PetscInt, PetscInt64, PetscInt64, PetscDataType);
2553ca90d2dSJacob Faibussowitsch PETSC_EXTERN PetscErrorCode PetscViewerStringSPrintf(PetscViewer, const char[], ...) PETSC_ATTRIBUTE_FORMAT(2, 3);
25636a9e3b9SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerStringSetString(PetscViewer, char[], size_t);
25736a9e3b9SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerStringGetStringRead(PetscViewer, const char *[], size_t *);
25836a9e3b9SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerStringSetOwnString(PetscViewer);
259014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDrawClear(PetscViewer);
260014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDrawSetHold(PetscViewer, PetscBool);
261014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDrawGetHold(PetscViewer, PetscBool *);
262014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDrawSetPause(PetscViewer, PetscReal);
263014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDrawGetPause(PetscViewer, PetscReal *);
264014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDrawSetInfo(PetscViewer, const char[], const char[], int, int, int, int);
265014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDrawResize(PetscViewer, int, int);
266014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDrawSetBounds(PetscViewer, PetscInt, const PetscReal *);
267014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerDrawGetBounds(PetscViewer, PetscInt *, const PetscReal **);
268014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerSocketSetConnection(PetscViewer, const char[], int);
269014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinarySkipInfo(PetscViewer);
270807ea322SDave May PETSC_EXTERN PetscErrorCode PetscViewerBinarySetSkipInfo(PetscViewer, PetscBool);
271807ea322SDave May PETSC_EXTERN PetscErrorCode PetscViewerBinaryGetSkipInfo(PetscViewer, PetscBool *);
272014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinarySetSkipOptions(PetscViewer, PetscBool);
273014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinaryGetSkipOptions(PetscViewer, PetscBool *);
274014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinarySetSkipHeader(PetscViewer, PetscBool);
275014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinaryGetSkipHeader(PetscViewer, PetscBool *);
276014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerBinaryReadStringArray(PetscViewer, char ***);
27778fbdcc8SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerBinaryWriteStringArray(PetscViewer, const char *const *);
278c655490fSBarry Smith 
279014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerFileSetName(PetscViewer, const char[]);
280014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerFileGetName(PetscViewer, const char **);
28177ed5343SBarry Smith 
282014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerVUGetPointer(PetscViewer, FILE **);
283014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerVUSetVecSeen(PetscViewer, PetscBool);
284014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerVUGetVecSeen(PetscViewer, PetscBool *);
2853ca90d2dSJacob Faibussowitsch PETSC_EXTERN PetscErrorCode PetscViewerVUPrintDeferred(PetscViewer, const char[], ...) PETSC_ATTRIBUTE_FORMAT(2, 3);
286014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerVUFlushDeferred(PetscViewer);
28755dcf840SMatthew Knepley 
2887e4fd573SVaclav Hapla /*@C
2897e4fd573SVaclav Hapla   PetscViewerVUSetMode - Sets the mode in which to open the file.
2907e4fd573SVaclav Hapla 
2917e4fd573SVaclav Hapla   Not Collective
2927e4fd573SVaclav Hapla 
2937e4fd573SVaclav Hapla   Input Parameters:
29487497f52SBarry Smith + viewer - The `PetscViewer`
2957e4fd573SVaclav Hapla - mode   - The file mode
2967e4fd573SVaclav Hapla 
2977e4fd573SVaclav Hapla   Level: deprecated
2987e4fd573SVaclav Hapla 
2997e4fd573SVaclav Hapla   Note:
30087497f52SBarry Smith   Use `PetscViewerFileSetMode()` instead.
3017e4fd573SVaclav Hapla 
3023f423023SBarry Smith .seealso: [](sec_viewers), `PetscViewer`, `PetscViewerFileSetMode()`
3037e4fd573SVaclav Hapla @*/
304edd03b47SJacob Faibussowitsch PETSC_DEPRECATED_FUNCTION(3, 15, 0, "PetscViewerFileSetMode()", ) static inline PetscErrorCode PetscViewerVUSetMode(PetscViewer viewer, PetscFileMode mode)
305d71ae5a4SJacob Faibussowitsch {
3069371c9d4SSatish Balay   return PetscViewerFileSetMode(viewer, mode);
3079371c9d4SSatish Balay }
3087e4fd573SVaclav Hapla 
309607a6623SBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerMathematicaInitializePackage(void);
310014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerMathematicaFinalizePackage(void);
311014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerMathematicaGetName(PetscViewer, const char **);
312014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerMathematicaSetName(PetscViewer, const char[]);
313014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerMathematicaClearName(PetscViewer);
314014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerMathematicaSkipPackets(PetscViewer, int);
3154ebda54eSMatthew Knepley 
316014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerSiloClearName(PetscViewer);
317014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerSiloClearMeshName(PetscViewer);
3184ebda54eSMatthew Knepley 
3199371c9d4SSatish Balay typedef enum {
3209371c9d4SSatish Balay   PETSC_VTK_INVALID,
3219371c9d4SSatish Balay   PETSC_VTK_POINT_FIELD,
3229371c9d4SSatish Balay   PETSC_VTK_POINT_VECTOR_FIELD,
3239371c9d4SSatish Balay   PETSC_VTK_CELL_FIELD,
3249371c9d4SSatish Balay   PETSC_VTK_CELL_VECTOR_FIELD
3259371c9d4SSatish Balay } PetscViewerVTKFieldType;
326e630c359SToby Isaac PETSC_EXTERN PetscErrorCode PetscViewerVTKAddField(PetscViewer, PetscObject, PetscErrorCode (*PetscViewerVTKWriteFunction)(PetscObject, PetscViewer), PetscInt, PetscViewerVTKFieldType, PetscBool, PetscObject);
327a8f87f1dSPatrick Sanan PETSC_EXTERN PetscErrorCode PetscViewerVTKGetDM(PetscViewer, PetscObject *);
328014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerVTKOpen(MPI_Comm, const char[], PetscFileMode, PetscViewer *);
3294061b8bfSJed Brown 
33077ed5343SBarry Smith /*
331d70abbfaSBarry Smith      These are all the default viewers that do not have to be explicitly opened
33277ed5343SBarry Smith */
333014dd563SJed Brown PETSC_EXTERN PetscViewer    PETSC_VIEWER_STDOUT_(MPI_Comm);
334014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIIGetStdout(MPI_Comm, PetscViewer *);
335014dd563SJed Brown PETSC_EXTERN PetscViewer    PETSC_VIEWER_STDERR_(MPI_Comm);
336014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerASCIIGetStderr(MPI_Comm, PetscViewer *);
337014dd563SJed Brown PETSC_EXTERN PetscViewer    PETSC_VIEWER_DRAW_(MPI_Comm);
338014dd563SJed Brown PETSC_EXTERN PetscViewer    PETSC_VIEWER_SOCKET_(MPI_Comm);
339014dd563SJed Brown PETSC_EXTERN PetscViewer    PETSC_VIEWER_BINARY_(MPI_Comm);
340014dd563SJed Brown PETSC_EXTERN PetscViewer    PETSC_VIEWER_MATLAB_(MPI_Comm);
341a75e6a4aSMatthew G. Knepley PETSC_EXTERN PetscViewer    PETSC_VIEWER_HDF5_(MPI_Comm);
3428135c375SStefano Zampini PETSC_EXTERN PetscViewer    PETSC_VIEWER_GLVIS_(MPI_Comm);
3431e50132fSMatthew G. Knepley PETSC_EXTERN PetscViewer    PETSC_VIEWER_EXODUSII_(MPI_Comm);
344014dd563SJed Brown PETSC_EXTERN PetscViewer    PETSC_VIEWER_MATHEMATICA_WORLD_PRIVATE;
3455311e20fSBarry Smith 
346f09f0971SVáclav Hapla /*MC
34787497f52SBarry Smith   PETSC_VIEWER_STDERR_SELF  - same as `PETSC_VIEWER_STDERR_`(PETSC_COMM_SELF)
348f09f0971SVáclav Hapla 
349f09f0971SVáclav Hapla   Level: beginner
350f09f0971SVáclav Hapla M*/
351b0a32e0cSBarry Smith #define PETSC_VIEWER_STDERR_SELF PETSC_VIEWER_STDERR_(PETSC_COMM_SELF)
352f09f0971SVáclav Hapla 
353f09f0971SVáclav Hapla /*MC
35487497f52SBarry Smith   PETSC_VIEWER_STDERR_WORLD  - same as `PETSC_VIEWER_STDERR_`(PETSC_COMM_WORLD)
355f09f0971SVáclav Hapla 
356f09f0971SVáclav Hapla   Level: beginner
357f09f0971SVáclav Hapla M*/
358b0a32e0cSBarry Smith #define PETSC_VIEWER_STDERR_WORLD PETSC_VIEWER_STDERR_(PETSC_COMM_WORLD)
35930de9b25SBarry Smith 
36030de9b25SBarry Smith /*MC
36187497f52SBarry Smith   PETSC_VIEWER_STDOUT_WORLD  - same as `PETSC_VIEWER_STDOUT_`(PETSC_COMM_WORLD)
36230de9b25SBarry Smith 
36330de9b25SBarry Smith   Level: beginner
36430de9b25SBarry Smith M*/
36530de9b25SBarry Smith #define PETSC_VIEWER_STDOUT_WORLD PETSC_VIEWER_STDOUT_(PETSC_COMM_WORLD)
36630de9b25SBarry Smith 
36730de9b25SBarry Smith /*MC
36887497f52SBarry Smith   PETSC_VIEWER_STDOUT_SELF  - same as `PETSC_VIEWER_STDOUT_`(PETSC_COMM_SELF)
36930de9b25SBarry Smith 
37030de9b25SBarry Smith   Level: beginner
37130de9b25SBarry Smith M*/
37230de9b25SBarry Smith #define PETSC_VIEWER_STDOUT_SELF PETSC_VIEWER_STDOUT_(PETSC_COMM_SELF)
37330de9b25SBarry Smith 
37430de9b25SBarry Smith /*MC
37587497f52SBarry Smith   PETSC_VIEWER_DRAW_WORLD  - same as `PETSC_VIEWER_DRAW_`(PETSC_COMM_WORLD)
37630de9b25SBarry Smith 
37730de9b25SBarry Smith   Level: intermediate
37830de9b25SBarry Smith M*/
379b0a32e0cSBarry Smith #define PETSC_VIEWER_DRAW_WORLD PETSC_VIEWER_DRAW_(PETSC_COMM_WORLD)
38030de9b25SBarry Smith 
38130de9b25SBarry Smith /*MC
38287497f52SBarry Smith   PETSC_VIEWER_DRAW_SELF  - same as `PETSC_VIEWER_DRAW_`(PETSC_COMM_SELF)
38330de9b25SBarry Smith 
38430de9b25SBarry Smith   Level: intermediate
38530de9b25SBarry Smith M*/
38630de9b25SBarry Smith #define PETSC_VIEWER_DRAW_SELF PETSC_VIEWER_DRAW_(PETSC_COMM_SELF)
38730de9b25SBarry Smith 
38830de9b25SBarry Smith /*MC
38987497f52SBarry Smith   PETSC_VIEWER_SOCKET_WORLD  - same as `PETSC_VIEWER_SOCKET_`(PETSC_COMM_WORLD)
39030de9b25SBarry Smith 
39130de9b25SBarry Smith   Level: intermediate
39230de9b25SBarry Smith M*/
393b0a32e0cSBarry Smith #define PETSC_VIEWER_SOCKET_WORLD PETSC_VIEWER_SOCKET_(PETSC_COMM_WORLD)
39430de9b25SBarry Smith 
39530de9b25SBarry Smith /*MC
39687497f52SBarry Smith   PETSC_VIEWER_SOCKET_SELF  - same as `PETSC_VIEWER_SOCKET_`(PETSC_COMM_SELF)
39730de9b25SBarry Smith 
39830de9b25SBarry Smith   Level: intermediate
39930de9b25SBarry Smith M*/
400b0a32e0cSBarry Smith #define PETSC_VIEWER_SOCKET_SELF PETSC_VIEWER_SOCKET_(PETSC_COMM_SELF)
40130de9b25SBarry Smith 
40230de9b25SBarry Smith /*MC
40387497f52SBarry Smith   PETSC_VIEWER_BINARY_WORLD  - same as `PETSC_VIEWER_BINARY_`(PETSC_COMM_WORLD)
40430de9b25SBarry Smith 
40530de9b25SBarry Smith   Level: intermediate
40630de9b25SBarry Smith M*/
407b0a32e0cSBarry Smith #define PETSC_VIEWER_BINARY_WORLD PETSC_VIEWER_BINARY_(PETSC_COMM_WORLD)
40830de9b25SBarry Smith 
40930de9b25SBarry Smith /*MC
41087497f52SBarry Smith   PETSC_VIEWER_BINARY_SELF  - same as `PETSC_VIEWER_BINARY_`(PETSC_COMM_SELF)
41130de9b25SBarry Smith 
41230de9b25SBarry Smith   Level: intermediate
41330de9b25SBarry Smith M*/
414b0a32e0cSBarry Smith #define PETSC_VIEWER_BINARY_SELF PETSC_VIEWER_BINARY_(PETSC_COMM_SELF)
41530de9b25SBarry Smith 
416cbb32127SBarry Smith /*MC
41787497f52SBarry Smith   PETSC_VIEWER_MATLAB_WORLD  - same as `PETSC_VIEWER_MATLAB_`(PETSC_COMM_WORLD)
418cbb32127SBarry Smith 
419cbb32127SBarry Smith   Level: intermediate
420cbb32127SBarry Smith M*/
421cbb32127SBarry Smith #define PETSC_VIEWER_MATLAB_WORLD PETSC_VIEWER_MATLAB_(PETSC_COMM_WORLD)
422cbb32127SBarry Smith 
423cbb32127SBarry Smith /*MC
42487497f52SBarry Smith   PETSC_VIEWER_MATLAB_SELF  - same as `PETSC_VIEWER_MATLAB_`(PETSC_COMM_SELF)
425cbb32127SBarry Smith 
426cbb32127SBarry Smith   Level: intermediate
427cbb32127SBarry Smith M*/
428cbb32127SBarry Smith #define PETSC_VIEWER_MATLAB_SELF PETSC_VIEWER_MATLAB_(PETSC_COMM_SELF)
429cbb32127SBarry Smith 
4307eb62a3eSMatthew Knepley #define PETSC_VIEWER_MATHEMATICA_WORLD (PetscViewerInitializeMathematicaWorld_Private(), PETSC_VIEWER_MATHEMATICA_WORLD_PRIVATE)
43165ef3172SBarry Smith 
4324a5f5e6cSBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerFlowControlStart(PetscViewer, PetscInt *, PetscInt *);
4339dddd249SSatish Balay PETSC_EXTERN PetscErrorCode PetscViewerFlowControlStepMain(PetscViewer, PetscInt, PetscInt *, PetscInt);
4349dddd249SSatish Balay PETSC_EXTERN PetscErrorCode PetscViewerFlowControlEndMain(PetscViewer, PetscInt *);
4354a5f5e6cSBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerFlowControlStepWorker(PetscViewer, PetscMPIInt, PetscInt *);
4364a5f5e6cSBarry Smith PETSC_EXTERN PetscErrorCode PetscViewerFlowControlEndWorker(PetscViewer, PetscInt *);
437edd03b47SJacob Faibussowitsch PETSC_DEPRECATED_FUNCTION(3, 15, 0, "PetscViewerFlowControlStepMain()", ) static inline PetscErrorCode PetscViewerFlowControlStepMaster(PetscViewer viewer, PetscInt i, PetscInt *mcnt, PetscInt cnt)
438d71ae5a4SJacob Faibussowitsch {
4399371c9d4SSatish Balay   return PetscViewerFlowControlStepMain(viewer, i, mcnt, cnt);
4409371c9d4SSatish Balay }
441edd03b47SJacob Faibussowitsch PETSC_DEPRECATED_FUNCTION(3, 15, 0, "PetscViewerFlowControlEndMain()", ) static inline PetscErrorCode PetscViewerFlowControlEndMaster(PetscViewer viewer, PetscInt *mcnt)
442d71ae5a4SJacob Faibussowitsch {
4439371c9d4SSatish Balay   return PetscViewerFlowControlEndMain(viewer, mcnt);
4449371c9d4SSatish Balay }
445e03d165dSBarry Smith 
44677ed5343SBarry Smith /*
447a5057860SBarry Smith    PetscViewer writes to MATLAB .mat file
448cbb32127SBarry Smith */
449014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerMatlabPutArray(PetscViewer, int, int, const PetscScalar *, const char *);
450014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerMatlabGetArray(PetscViewer, int, int, PetscScalar *, const char *);
451014dd563SJed Brown PETSC_EXTERN PetscErrorCode PetscViewerMatlabPutVariable(PetscViewer, const char *, void *);
452cbb32127SBarry Smith 
453e04113cfSBarry Smith #if defined(PETSC_HAVE_SAWS)
454e04113cfSBarry Smith PETSC_EXTERN PetscErrorCode PetscObjectViewSAWs(PetscObject, PetscViewer);
455bfb97211SBarry Smith #endif
456bfb97211SBarry Smith 
457b9617806SBarry Smith /*S
4583f423023SBarry Smith    PetscViewers - Abstract collection of `PetscViewer`s. It is stored as an expandable array of viewers.
459b9617806SBarry Smith 
460b9617806SBarry Smith    Level: intermediate
461b9617806SBarry Smith 
462d1f92df0SBarry Smith .seealso: [](sec_viewers), `PetscViewerCreate()`, `PetscViewerSetType()`, `PetscViewerType`, `PetscViewer`, `PetscViewersCreate()`,
463db781477SPatrick Sanan           `PetscViewersGetViewer()`
464b9617806SBarry Smith S*/
46595fbd943SSatish Balay typedef struct _n_PetscViewers *PetscViewers;
466014dd563SJed Brown PETSC_EXTERN PetscErrorCode     PetscViewersCreate(MPI_Comm, PetscViewers *);
467014dd563SJed Brown PETSC_EXTERN PetscErrorCode     PetscViewersDestroy(PetscViewers *);
468014dd563SJed Brown PETSC_EXTERN PetscErrorCode     PetscViewersGetViewer(PetscViewers, PetscInt, PetscViewer *);
469d132466eSBarry Smith 
470cb5b572fSBarry Smith #endif
471