xref: /petsc/include/petscsys.h (revision 7f5a67d67c59f1aff48eb97e2c700311e2bac8d9)
1 /* $Id: petscsys.h,v 1.63 2001/08/07 21:32:24 bsmith Exp $ */
2 /*
3     Provides access to system related and general utility routines.
4 */
5 #if !defined(__PETSCSYS_H)
6 #define __PETSCSYS_H
7 
8 #include "petsc.h"
9 
10 EXTERN int  PetscGetArchType(char[],int);
11 EXTERN int  PetscGetHostName(char[],int);
12 EXTERN int  PetscGetUserName(char[],int);
13 EXTERN int  PetscGetProgramName(char[],int);
14 EXTERN int  PetscSetProgramName(const char[]);
15 EXTERN int  PetscGetDate(char[],int);
16 EXTERN int  PetscSetInitialDate(void);
17 EXTERN int  PetscGetInitialDate(char[],int);
18 
19 EXTERN int  PetscSortInt(int,int[]);
20 EXTERN int  PetscSortIntWithPermutation(int,const int[],int[]);
21 EXTERN int  PetscSortIntWithArray(int,int[],int[]);
22 EXTERN int  PetscSortReal(int,PetscReal[]);
23 EXTERN int  PetscSortRealWithPermutation(int,const PetscReal[],int[]);
24 
25 EXTERN int  PetscSetDisplay(void);
26 EXTERN int  PetscGetDisplay(char[],int);
27 
28 #define PETSCRANDOM_COOKIE PETSC_COOKIE+19
29 
30 typedef enum { RANDOM_DEFAULT,RANDOM_DEFAULT_REAL,
31                RANDOM_DEFAULT_IMAGINARY } PetscRandomType;
32 
33 typedef struct _p_PetscRandom*   PetscRandom;
34 
35 EXTERN int PetscRandomCreate(MPI_Comm,PetscRandomType,PetscRandom*);
36 EXTERN int PetscRandomGetValue(PetscRandom,PetscScalar*);
37 EXTERN int PetscRandomSetInterval(PetscRandom,PetscScalar,PetscScalar);
38 EXTERN int PetscRandomDestroy(PetscRandom);
39 
40 EXTERN int PetscGetFullPath(const char[],char[],int);
41 EXTERN int PetscGetRelativePath(const char[],char[],int);
42 EXTERN int PetscGetWorkingDirectory(char[],int);
43 EXTERN int PetscGetRealPath(char[],char[]);
44 EXTERN int PetscGetHomeDirectory(char[],int);
45 EXTERN int PetscTestFile(const char[],char,PetscTruth*);
46 EXTERN int PetscTestDirectory(const char[],char,PetscTruth*);
47 EXTERN int PetscBinaryRead(int,void*,int,PetscDataType);
48 EXTERN int PetscSynchronizedBinaryRead(MPI_Comm,int,void*,int,PetscDataType);
49 EXTERN int PetscBinaryWrite(int,void*,int,PetscDataType,int);
50 EXTERN int PetscBinaryOpen(const char[],int,int *);
51 EXTERN int PetscBinaryClose(int);
52 EXTERN int PetscSharedTmp(MPI_Comm,PetscTruth *);
53 EXTERN int PetscSharedWorkingDirectory(MPI_Comm,PetscTruth *);
54 EXTERN int PetscGetTmp(MPI_Comm,char *,int);
55 EXTERN int PetscFileRetrieve(MPI_Comm,const char *,char *,int,PetscTruth*);
56 EXTERN int PetscLs(MPI_Comm,const char[],char*,int,PetscTruth*);
57 EXTERN int PetscDLLibraryCCAAppend(MPI_Comm,PetscDLLibraryList*,const char[]);
58 
59 /*
60    In binary files variables are stored using the following lengths,
61   regardless of how they are stored in memory on any one particular
62   machine. Use these rather then sizeof() in computing sizes for
63   PetscBinarySeek().
64 */
65 #define PETSC_BINARY_INT_SIZE    (32/8)
66 #define PETSC_BINARY_FLOAT_SIZE  (32/8)
67 #define PETSC_BINARY_CHAR_SIZE    (8/8)
68 #define PETSC_BINARY_SHORT_SIZE  (16/8)
69 #define PETSC_BINARY_DOUBLE_SIZE (64/8)
70 #define PETSC_BINARY_SCALAR_SIZE sizeof(PetscScalar)
71 
72 typedef enum {PETSC_BINARY_SEEK_SET = 0,PETSC_BINARY_SEEK_CUR = 1,PETSC_BINARY_SEEK_END = 2} PetscBinarySeekType;
73 EXTERN int PetscBinarySeek(int,int,PetscBinarySeekType,int*);
74 EXTERN int PetscSynchronizedBinarySeek(MPI_Comm,int,int,PetscBinarySeekType,int*);
75 
76 EXTERN int PetscSetDebugger(const char[],PetscTruth);
77 EXTERN int PetscSetDefaultDebugger(void);
78 EXTERN int PetscSetDebuggerFromString(char*);
79 EXTERN int PetscAttachDebugger(void);
80 EXTERN int PetscStopForDebugger(void);
81 
82 EXTERN int PetscGatherNumberOfMessages(MPI_Comm,int*,int*,int*);
83 EXTERN int PetscGatherMessageLengths(MPI_Comm,int,int,int*,int**,int**);
84 EXTERN int PetscPostIrecvInt(MPI_Comm,int,int,int*,int*,int***,MPI_Request**);
85 EXTERN int PetscPostIrecvScalar(MPI_Comm,int,int,int*,int*,PetscScalar***,MPI_Request**);
86 
87 EXTERN int PetscSSEIsEnabled(MPI_Comm,PetscTruth *,PetscTruth *);
88 
89 /* ParameterDict objects encapsulate arguments to generic functions, like mechanisms over interfaces */
90 EXTERN int ParameterDictCreate(MPI_Comm, ParameterDict *);
91 EXTERN int ParameterDictDestroy(ParameterDict);
92 EXTERN int ParameterDictRemove(ParameterDict, const char []);
93 EXTERN int ParameterDictSetInteger(ParameterDict, const char [], int);
94 EXTERN int ParameterDictSetDouble(ParameterDict, const char [], double);
95 EXTERN int ParameterDictSetObject(ParameterDict, const char [], void *);
96 EXTERN int ParameterDictGetInteger(ParameterDict, const char [], int *);
97 EXTERN int ParameterDictGetDouble(ParameterDict, const char [], double *);
98 EXTERN int ParameterDictGetObject(ParameterDict, const char [], void **);
99 
100 /* Parallel communication routines */
101 /*E
102   InsertMode - Whether entries are inserted or added into vectors or matrices
103 
104   Level: beginner
105 
106 .seealso: VecSetValues(), MatSetValues(), VecSetValue(), VecSetValuesBlocked(),
107           VecSetValuesLocal(), VecSetValuesBlockedLocal(), MatSetValuesBlocked(),
108           MatSetValuesBlockedLocal(), MatSetValuesLocal()
109 E*/
110 typedef enum {NOT_SET_VALUES, INSERT_VALUES, ADD_VALUES, MAX_VALUES} InsertMode;
111 /*E
112   ScatterMode - Determines the direction of a scatter
113 
114   Level: beginner
115 
116 .seealso: VecScatter, VecScatterBegin(), VecScatterEnd()
117 E*/
118 typedef enum {SCATTER_FORWARD=0, SCATTER_REVERSE=1, SCATTER_FORWARD_LOCAL=2, SCATTER_REVERSE_LOCAL=3, SCATTER_LOCAL=2} ScatterMode;
119 
120 EXTERN int PetscGhostExchange(MPI_Comm, int, int *, int *, PetscDataType, int *, InsertMode, ScatterMode, void *, void *);
121 
122 #endif /* __PETSCSYS_H */
123