xref: /petsc/include/petscviewer.h (revision 456192e25527e6dfd94efe19f31bdabe85ed0893)
173f4d377SMatthew Knepley /* $Id: petscviewer.h,v 1.85 2001/08/06 21:13:28 bsmith Exp $ */
284cb2905SBarry Smith /*
3b0a32e0cSBarry Smith      PetscViewers are objects where other objects can be looked at or stored.
484cb2905SBarry Smith */
53c119ea2SBarry Smith 
60a835dfdSSatish Balay #if !defined(__PETSCVIEWER_H)
70a835dfdSSatish Balay #define __PETSCVIEWER_H
82eb8c8abSBarry Smith 
98ba1e511SMatthew Knepley extern int PETSC_VIEWER_COOKIE;
108ba1e511SMatthew Knepley 
11b9617806SBarry Smith /*S
12b9617806SBarry Smith      PetscViewer - Abstract PETSc object that helps view (in ASCII, binary, graphically etc)
13b9617806SBarry Smith          other PETSc objects
14b9617806SBarry Smith 
15b9617806SBarry Smith    Level: beginner
16b9617806SBarry Smith 
17b9617806SBarry Smith   Concepts: viewing
18b9617806SBarry Smith 
19b9617806SBarry Smith .seealso:  PetscViewerCreate(), PetscViewerSetType(), PetscViewerType
20b9617806SBarry Smith S*/
21b0a32e0cSBarry Smith typedef struct _p_PetscViewer* PetscViewer;
223c119ea2SBarry Smith 
233c119ea2SBarry Smith /*
24b0a32e0cSBarry Smith     petsc.h must be included AFTER the definition of PetscViewer for ADIC to
253c119ea2SBarry Smith    process correctly.
263c119ea2SBarry Smith */
272eb8c8abSBarry Smith #include "petsc.h"
282eb8c8abSBarry Smith 
29b9617806SBarry Smith /*E
30b9617806SBarry Smith     PetscViewerType - String with the name of a PETSc PETScViewer
31b9617806SBarry Smith 
32b9617806SBarry Smith    Level: beginner
33b9617806SBarry Smith 
34b9617806SBarry Smith .seealso: PetscViewerSetType(), PetscViewer
35b9617806SBarry Smith E*/
36b9617806SBarry Smith typedef char* PetscViewerType;
37b0a32e0cSBarry Smith #define PETSC_VIEWER_SOCKET       "socket"
38b0a32e0cSBarry Smith #define PETSC_VIEWER_ASCII        "ascii"
39fb9695e5SSatish Balay #define PETSC_VIEWER_BINARY       "binary"
40b0a32e0cSBarry Smith #define PETSC_VIEWER_STRING       "string"
41fb9695e5SSatish Balay #define PETSC_VIEWER_DRAW         "draw"
42b0a32e0cSBarry Smith #define PETSC_VIEWER_AMS          "ams"
4344c73c46SMatthew Knepley #define PETSC_VIEWER_VU           "vu"
444ebda54eSMatthew Knepley #define PETSC_VIEWER_MATHEMATICA  "mathematica"
454ebda54eSMatthew Knepley #define PETSC_VIEWER_SILO         "silo"
4677ed5343SBarry Smith 
47b0a32e0cSBarry Smith extern PetscFList PetscViewerList;
48b0a32e0cSBarry Smith EXTERN int PetscViewerRegisterAll(char *);
49b0a32e0cSBarry Smith EXTERN int PetscViewerRegisterDestroy(void);
507b2a1423SBarry Smith 
51b0a32e0cSBarry Smith EXTERN int PetscViewerRegister(char*,char*,char*,int(*)(PetscViewer));
52aa482453SBarry Smith #if defined(PETSC_USE_DYNAMIC_LIBRARIES)
53b0a32e0cSBarry Smith #define PetscViewerRegisterDynamic(a,b,c,d) PetscViewerRegister(a,b,c,0)
547b2a1423SBarry Smith #else
55b0a32e0cSBarry Smith #define PetscViewerRegisterDynamic(a,b,c,d) PetscViewerRegister(a,b,c,d)
567b2a1423SBarry Smith #endif
57b0a32e0cSBarry Smith EXTERN int PetscViewerCreate(MPI_Comm,PetscViewer*);
58b0a32e0cSBarry Smith EXTERN int PetscViewerSetFromOptions(PetscViewer);
597b2a1423SBarry Smith 
60b0a32e0cSBarry Smith EXTERN int PetscViewerASCIIOpen(MPI_Comm,const char[],PetscViewer*);
61b0a32e0cSBarry Smith typedef enum {PETSC_BINARY_RDONLY,PETSC_BINARY_WRONLY,PETSC_BINARY_CREATE} PetscViewerBinaryType;
62b0a32e0cSBarry Smith EXTERN int PetscViewerBinaryOpen(MPI_Comm,const char[],PetscViewerBinaryType,PetscViewer*);
63b0a32e0cSBarry Smith EXTERN int PetscViewerSocketOpen(MPI_Comm,const char[],int,PetscViewer*);
64b0a32e0cSBarry Smith EXTERN int PetscViewerStringOpen(MPI_Comm,char[],int,PetscViewer*);
65b0a32e0cSBarry Smith EXTERN int PetscViewerDrawOpen(MPI_Comm,const char[],const char[],int,int,int,int,PetscViewer*);
66b0a32e0cSBarry Smith EXTERN int PetscViewerAMSSetCommName(PetscViewer,const char[]);
674ebda54eSMatthew Knepley EXTERN int PetscViewerMathematicaOpen(MPI_Comm, int, const char[], const char[], PetscViewer *);
684ebda54eSMatthew Knepley EXTERN int PetscViewerSiloOpen(MPI_Comm, const char[], PetscViewer *);
694b0e389bSBarry Smith 
70b0a32e0cSBarry Smith EXTERN int PetscViewerGetType(PetscViewer,PetscViewerType*);
71b0a32e0cSBarry Smith EXTERN int PetscViewerSetType(PetscViewer,PetscViewerType);
72b0a32e0cSBarry Smith EXTERN int PetscViewerDestroy(PetscViewer);
73b0a32e0cSBarry Smith EXTERN int PetscViewerGetSingleton(PetscViewer,PetscViewer*);
74b0a32e0cSBarry Smith EXTERN int PetscViewerRestoreSingleton(PetscViewer,PetscViewer*);
75ae39576cSLois Curfman McInnes 
76090de74eSSatish Balay 
77b9617806SBarry Smith /*E
78b9617806SBarry Smith     PetscViewerFormat - Way a viewer presents the object
79b9617806SBarry Smith 
80b9617806SBarry Smith    Level: beginner
81b9617806SBarry Smith 
82b9617806SBarry Smith .seealso: PetscViewerSetFormat(), PetscViewer, PetscViewerType, PetscViewerPushFormat(), PetscViewerPopFormat()
83b9617806SBarry Smith E*/
84fb9695e5SSatish Balay typedef enum {
85f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_DEFAULT,
86f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_MATLAB,
874ebda54eSMatthew Knepley   PETSC_VIEWER_ASCII_MATHEMATICA,
88f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_IMPL,
89f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_INFO,
90*456192e2SBarry Smith   PETSC_VIEWER_ASCII_INFO_DETAIL,
91f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_COMMON,
92f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_SYMMODU,
93f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_INDEX,
94f3ef73ceSBarry Smith   PETSC_VIEWER_ASCII_DENSE,
95f3ef73ceSBarry Smith   PETSC_VIEWER_BINARY_DEFAULT,
96f3ef73ceSBarry Smith   PETSC_VIEWER_BINARY_NATIVE,
97f3ef73ceSBarry Smith   PETSC_VIEWER_DRAW_BASIC,
98f3ef73ceSBarry Smith   PETSC_VIEWER_DRAW_LG,
99f3ef73ceSBarry Smith   PETSC_VIEWER_DRAW_CONTOUR,
100f3ef73ceSBarry Smith   PETSC_VIEWER_DRAW_PORTS,
101f3ef73ceSBarry Smith   PETSC_VIEWER_NATIVE,
1024aedb280SBarry Smith   PETSC_VIEWER_NOFORMAT,
1034aedb280SBarry Smith   PETSC_VIEWER_ASCII_FACTOR_INFO} PetscViewerFormat;
104090de74eSSatish Balay 
105f3ef73ceSBarry Smith EXTERN int PetscViewerSetFormat(PetscViewer,PetscViewerFormat);
106f3ef73ceSBarry Smith EXTERN int PetscViewerPushFormat(PetscViewer,PetscViewerFormat);
107b0a32e0cSBarry Smith EXTERN int PetscViewerPopFormat(PetscViewer);
108f3ef73ceSBarry Smith EXTERN int PetscViewerGetFormat(PetscViewer,PetscViewerFormat*);
109b0a32e0cSBarry Smith EXTERN int PetscViewerFlush(PetscViewer);
1104b0e389bSBarry Smith 
11177ed5343SBarry Smith /*
11277ed5343SBarry Smith    Operations explicit to a particular class of viewers
11377ed5343SBarry Smith */
114ed5c6e3eSMatthew Knepley 
115ed5c6e3eSMatthew Knepley /*E
116ed5c6e3eSMatthew Knepley   PetscViewerFormat - Access mode for a file.
117ed5c6e3eSMatthew Knepley 
118ed5c6e3eSMatthew Knepley   Level: beginner
119ed5c6e3eSMatthew Knepley 
120ed5c6e3eSMatthew Knepley .seealso: PetscViewerASCIISetMode()
121ed5c6e3eSMatthew Knepley E*/
122ed5c6e3eSMatthew Knepley typedef enum {FILE_MODE_READ, FILE_MODE_WRITE, FILE_MODE_APPEND, FILE_MODE_UPDATE, FILE_MODE_APPEND_UPDATE} PetscFileMode;
123ed5c6e3eSMatthew Knepley 
124b0a32e0cSBarry Smith EXTERN int PetscViewerASCIIGetPointer(PetscViewer,FILE**);
125ed5c6e3eSMatthew Knepley EXTERN int PetscViewerASCIISetMode(PetscViewer,PetscFileMode);
126f80b7eb0SBarry Smith EXTERN int PetscViewerASCIIPrintf(PetscViewer,const char[],...) PETSC_PRINTF_FORMAT_CHECK(2,3);
127f80b7eb0SBarry Smith EXTERN int PetscViewerASCIISynchronizedPrintf(PetscViewer,const char[],...) PETSC_PRINTF_FORMAT_CHECK(2,3);
128b0a32e0cSBarry Smith EXTERN int PetscViewerASCIIPushTab(PetscViewer);
129b0a32e0cSBarry Smith EXTERN int PetscViewerASCIIPopTab(PetscViewer);
130b0a32e0cSBarry Smith EXTERN int PetscViewerASCIIUseTabs(PetscViewer,PetscTruth);
131b0a32e0cSBarry Smith EXTERN int PetscViewerASCIISetTab(PetscViewer,int);
132b0a32e0cSBarry Smith EXTERN int PetscViewerBinaryGetDescriptor(PetscViewer,int*);
133b0a32e0cSBarry Smith EXTERN int PetscViewerBinaryGetInfoPointer(PetscViewer,FILE **);
134b0a32e0cSBarry Smith EXTERN int PetscViewerBinarySetType(PetscViewer,PetscViewerBinaryType);
135f80b7eb0SBarry Smith EXTERN int PetscViewerStringSPrintf(PetscViewer,char *,...) PETSC_PRINTF_FORMAT_CHECK(2,3);
136b0a32e0cSBarry Smith EXTERN int PetscViewerStringSetString(PetscViewer,char[],int);
137b0a32e0cSBarry Smith EXTERN int PetscViewerDrawClear(PetscViewer);
138b0a32e0cSBarry Smith EXTERN int PetscViewerDrawSetInfo(PetscViewer,const char[],const char[],int,int,int,int);
139b0a32e0cSBarry Smith EXTERN int PetscViewerSocketSetConnection(PetscViewer,const char[],int);
140bba1ac68SSatish Balay EXTERN int PetscViewerBinarySkipInfo(PetscViewer);
14108641331SSatish Balay EXTERN int PetscViewerBinaryLoadInfo(PetscViewer);
14208641331SSatish Balay 
143c655490fSBarry Smith 
144b0a32e0cSBarry Smith EXTERN int PetscViewerSetFilename(PetscViewer,const char[]);
145b0a32e0cSBarry Smith EXTERN int PetscViewerGetFilename(PetscViewer,char**);
14677ed5343SBarry Smith 
14744c6da4fSMatthew Knepley EXTERN int PetscPLAPACKInitializePackage(char *);
14865804fbbSSatish Balay EXTERN int PetscPLAPACKFinalizePackage(void);
14944c6da4fSMatthew Knepley 
15055dcf840SMatthew Knepley EXTERN int PetscViewerVUGetPointer(PetscViewer, FILE**);
151c4b95c56SMatthew Knepley EXTERN int PetscViewerVUSetMode(PetscViewer, PetscFileMode);
152c4b95c56SMatthew Knepley EXTERN int PetscViewerVUSetVecSeen(PetscViewer, PetscTruth);
153c4b95c56SMatthew Knepley EXTERN int PetscViewerVUGetVecSeen(PetscViewer, PetscTruth *);
154f80b7eb0SBarry Smith EXTERN int PetscViewerVUPrintDeferred(PetscViewer, const char [], ...) PETSC_PRINTF_FORMAT_CHECK(2,3);
155c4b95c56SMatthew Knepley EXTERN int PetscViewerVUFlushDeferred(PetscViewer);
15655dcf840SMatthew Knepley 
15744c6da4fSMatthew Knepley EXTERN int PetscViewerMathematicaInitializePackage(char *);
15886e45947SSatish Balay EXTERN int PetscViewerMathematicaFinalizePackage(void);
159918c3ce8SMatthew Knepley EXTERN int PetscViewerMathematicaGetName(PetscViewer, const char **);
1607eb62a3eSMatthew Knepley EXTERN int PetscViewerMathematicaSetName(PetscViewer, const char []);
1617eb62a3eSMatthew Knepley EXTERN int PetscViewerMathematicaClearName(PetscViewer);
1627eb62a3eSMatthew Knepley EXTERN int PetscViewerMathematicaSkipPackets(PetscViewer, int);
1634ebda54eSMatthew Knepley 
1647eb62a3eSMatthew Knepley EXTERN int PetscViewerSiloGetName(PetscViewer, char **);
1657eb62a3eSMatthew Knepley EXTERN int PetscViewerSiloSetName(PetscViewer, const char []);
1667eb62a3eSMatthew Knepley EXTERN int PetscViewerSiloClearName(PetscViewer);
1677eb62a3eSMatthew Knepley EXTERN int PetscViewerSiloGetMeshName(PetscViewer, char **);
1687eb62a3eSMatthew Knepley EXTERN int PetscViewerSiloSetMeshName(PetscViewer, const char []);
1697eb62a3eSMatthew Knepley EXTERN int PetscViewerSiloClearMeshName(PetscViewer);
1704ebda54eSMatthew Knepley 
17177ed5343SBarry Smith /*
17277ed5343SBarry Smith      These are all the default viewers that do not have
17377ed5343SBarry Smith    to be explicitly opened
17477ed5343SBarry Smith */
175b0a32e0cSBarry Smith EXTERN PetscViewer PETSC_VIEWER_STDOUT_(MPI_Comm);
176b0a32e0cSBarry Smith EXTERN PetscViewer PETSC_VIEWER_STDERR_(MPI_Comm);
177b0a32e0cSBarry Smith EXTERN PetscViewer PETSC_VIEWER_DRAW_(MPI_Comm);
178b0a32e0cSBarry Smith EXTERN PetscViewer PETSC_VIEWER_SOCKET_(MPI_Comm);
179b0a32e0cSBarry Smith EXTERN PetscViewer PETSC_VIEWER_BINARY_(MPI_Comm);
1807eb62a3eSMatthew Knepley EXTERN PetscViewer PETSC_VIEWER_MATHEMATICA_WORLD_PRIVATE;
1815311e20fSBarry Smith 
182b0a32e0cSBarry Smith #define PETSC_VIEWER_STDOUT_SELF  PETSC_VIEWER_STDOUT_(PETSC_COMM_SELF)
183b0a32e0cSBarry Smith #define PETSC_VIEWER_STDOUT_WORLD PETSC_VIEWER_STDOUT_(PETSC_COMM_WORLD)
184b0a32e0cSBarry Smith #define PETSC_VIEWER_STDERR_SELF  PETSC_VIEWER_STDERR_(PETSC_COMM_SELF)
185b0a32e0cSBarry Smith #define PETSC_VIEWER_STDERR_WORLD PETSC_VIEWER_STDERR_(PETSC_COMM_WORLD)
186b0a32e0cSBarry Smith #define PETSC_VIEWER_DRAW_SELF    PETSC_VIEWER_DRAW_(PETSC_COMM_SELF)
187b0a32e0cSBarry Smith #define PETSC_VIEWER_DRAW_WORLD   PETSC_VIEWER_DRAW_(PETSC_COMM_WORLD)
188b0a32e0cSBarry Smith #define PETSC_VIEWER_SOCKET_WORLD PETSC_VIEWER_SOCKET_(PETSC_COMM_WORLD)
189b0a32e0cSBarry Smith #define PETSC_VIEWER_SOCKET_SELF  PETSC_VIEWER_SOCKET_(PETSC_COMM_SELF)
190b0a32e0cSBarry Smith #define PETSC_VIEWER_BINARY_WORLD PETSC_VIEWER_BINARY_(PETSC_COMM_WORLD)
191b0a32e0cSBarry Smith #define PETSC_VIEWER_BINARY_SELF  PETSC_VIEWER_BINARY_(PETSC_COMM_SELF)
1927eb62a3eSMatthew Knepley #define PETSC_VIEWER_MATHEMATICA_WORLD (PetscViewerInitializeMathematicaWorld_Private(),PETSC_VIEWER_MATHEMATICA_WORLD_PRIVATE)
19365ef3172SBarry Smith 
19477ed5343SBarry Smith /*
195b0a32e0cSBarry Smith     PetscViewer based on the ALICE Memory Snooper
19677ed5343SBarry Smith */
197aa482453SBarry Smith #if defined(PETSC_HAVE_AMS)
198cb5b572fSBarry Smith #include "ams.h"
199b0a32e0cSBarry Smith EXTERN int         PetscViewerAMSGetAMSComm(PetscViewer,AMS_Comm *);
200b0a32e0cSBarry Smith EXTERN int         PetscViewerAMSOpen(MPI_Comm,const char[],PetscViewer*);
201b1607693SBarry Smith EXTERN int         PetscViewerAMSLock(PetscViewer);
202b0a32e0cSBarry Smith EXTERN PetscViewer PETSC_VIEWER_AMS_(MPI_Comm);
203b0a32e0cSBarry Smith EXTERN int         PETSC_VIEWER_AMS_Destroy(MPI_Comm);
204b0a32e0cSBarry Smith #define PETSC_VIEWER_AMS_WORLD PETSC_VIEWER_AMS_(PETSC_COMM_WORLD)
2052eb8c8abSBarry Smith #endif
206cb5b572fSBarry Smith 
207f2b01315SBarry Smith /*
208b0a32e0cSBarry Smith     PetscViewer utility routines used by PETSc that are not normally used
209f2b01315SBarry Smith    by users.
210f2b01315SBarry Smith */
21187828ca2SBarry Smith EXTERN int  PetscViewerSocketPutScalar(PetscViewer,int,int,PetscScalar*);
21287828ca2SBarry Smith EXTERN int  PetscViewerSocketPutReal(PetscViewer,int,int,PetscReal*);
213b0a32e0cSBarry Smith EXTERN int  PetscViewerSocketPutInt(PetscViewer,int,int*);
21487828ca2SBarry Smith EXTERN int  PetscViewerSocketPutSparse_Private(PetscViewer,int,int,int,PetscScalar*,int*,int *);
215b0a32e0cSBarry Smith EXTERN int  PetscViewerDestroyAMS_Private(void);
216f2b01315SBarry Smith 
217b9617806SBarry Smith /*S
218b9617806SBarry Smith      PetscViewers - Abstract collection of PetscViewers
219b9617806SBarry Smith 
220b9617806SBarry Smith    Level: intermediate
221b9617806SBarry Smith 
222b9617806SBarry Smith   Concepts: viewing
223b9617806SBarry Smith 
224b9617806SBarry Smith .seealso:  PetscViewerCreate(), PetscViewerSetType(), PetscViewerType, PetscViewer, PetscViewersCreate(),
225b9617806SBarry Smith            PetscViewersGetViewer()
226b9617806SBarry Smith S*/
227b0a32e0cSBarry Smith typedef struct _p_PetscViewers* PetscViewers;
228b0a32e0cSBarry Smith EXTERN int PetscViewersCreate(MPI_Comm,PetscViewers*);
229b0a32e0cSBarry Smith EXTERN int PetscViewersDestroy(PetscViewers);
230b0a32e0cSBarry Smith EXTERN int PetscViewersGetViewer(PetscViewers,int,PetscViewer*);
231d132466eSBarry Smith 
232cb5b572fSBarry Smith #endif
233