source: issm/trunk/src/c/objects/Params/PetscVecParam.h@ 3834

Last change on this file since 3834 was 3834, checked in by Mathieu Morlighem, 15 years ago

almost there

File size: 2.6 KB
Line 
1/*! \file PetscVecParam.h
2 * \brief: header file for triavertexinput object
3 */
4
5
6#ifndef _PETSCVECPARAM_H_
7#define _PETSCVECPARAM_H_
8
9/*Headers:*/
10/*{{{1*/
11
12#ifdef HAVE_CONFIG_H
13 #include "config.h"
14#else
15#error "Cannot compile with HAVE_CONFIG_H symbol! run configure first!"
16#endif
17
18#ifdef _SERIAL_
19#include <mex.h>
20#endif
21
22
23#include "./Param.h"
24#include "../../include/include.h"
25#include "../../shared/shared.h"
26#include "../../include/include.h"
27#include "../../include/include.h"
28/*}}}*/
29
30class PetscVecParam: public Param{
31
32 private:
33 /*just hold 3 values for 3 vertices: */
34 int enum_type;
35 Vec value;
36
37 public:
38 /*constructors, destructors: {{{1*/
39 PetscVecParam();
40 PetscVecParam(int enum_type,Vec value);
41 ~PetscVecParam();
42 /*}}}*/
43 /*Object methods: {{{1*/
44 Object* copy();
45 void DeepEcho();
46 void Demarshall(char** pmarshalled_dataset);
47 void Echo();
48 int Enum();
49 int Id();
50 void Marshall(char** pmarshalled_dataset);
51 int MarshallSize();
52 int MyRank();
53 void UpdateInputsFromVector(double* vector, int name, int type);
54 void UpdateInputsFromVector(int* vector, int name, int type);
55 void UpdateInputsFromVector(bool* vector, int name, int type);
56 void UpdateInputsFromConstant(double constant, int name);
57 void UpdateInputsFromConstant(int constant, int name);
58 void UpdateInputsFromConstant(bool constant, int name);
59
60 void UpdateInputsFromSolution(double* solution, int analysis_type, int sub_analysis_type){ISSMERROR("Not implemented yet!");}
61
62 /*}}}*/
63 /*Param methods: {{{1*/
64 int EnumType(){return enum_type;}
65 void GetParameterValue(bool* pbool){ISSMERROR("PetscVec param cannot return a bool");}
66 void GetParameterValue(int* pinteger){ISSMERROR("PetscVec param cannot return an integer");}
67 void GetParameterValue(double* pdouble){ISSMERROR("PetscVec param cannot return a double");}
68 void GetParameterValue(char** pstring){ISSMERROR("PetscVec param cannot return a string");}
69 void GetParameterValue(char*** pstringarray,int* pM){ISSMERROR("PetscVec param cannot return a string arrayl");}
70 void GetParameterValue(double** pdoublearray,int* pM){ISSMERROR("PetscVec param cannot return a double array");}
71 void GetParameterValue(double** pdoublearray,int* pM, int* pN){ISSMERROR("PetscVec param cannot return a double array");}
72 void GetParameterValue(Mat* pmat){ISSMERROR("PetscVec param cannot return a Mat");}
73 void GetParameterValue(Vec* poutput);
74 char* GetParameterName(void);
75 void Process(double* partition,int numberofvertices);
76 #ifdef _SERIAL_
77 void SetMatlabField(mxArray* dataref);
78 #endif
79
80 /*}}}*/
81};
82#endif /* _PETSCVECPARAM_H */
Note: See TracBrowser for help on using the repository browser.