source: issm/trunk/src/c/objects/Params/BoolParam.h@ 4043

Last change on this file since 4043 was 4043, checked in by Eric.Larour, 15 years ago

Changing to new framework where analysis_type and sub_analysis_type are picked up in the parameters, whenever needed.
This greatly simplifies the API of the code -> don't have to carry along analysis_type and sub_analysis_type.

File size: 2.9 KB
Line 
1/*! \file BoolParam.h
2 * \brief: header file for triavertexinput object
3 */
4
5
6#ifndef _BOOLPARAM_H_
7#define _BOOLPARAM_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 BoolParam: public Param{
31
32 public:
33 /*just hold 3 values for 3 vertices: */
34 int enum_type;
35 IssmBool value;
36
37 /*constructors, destructors: {{{1*/
38 BoolParam();
39 BoolParam(int enum_type,IssmBool value);
40 ~BoolParam();
41 /*}}}*/
42 /*Object methods: {{{1*/
43 Object* copy();
44 void DeepEcho();
45 void Demarshall(char** pmarshalled_dataset);
46 void Echo();
47 int Enum();
48 int Id();
49 void Marshall(char** pmarshalled_dataset);
50 int MarshallSize();
51 int MyRank();
52 void UpdateInputsFromVector(double* vector, int name, int type);
53 void UpdateInputsFromVector(int* vector, int name, int type);
54 void UpdateInputsFromVector(bool* vector, int name, int type);
55 void UpdateInputsFromConstant(double constant, int name);
56 void UpdateInputsFromConstant(int constant, int name);
57 void UpdateInputsFromConstant(bool constant, int name);
58 void UpdateInputsFromSolution(double* solution){ISSMERROR("Not implemented yet!");}
59
60 /*}}}*/
61 /*Param methods: {{{1*/
62 int EnumType(){return enum_type;}
63 void GetParameterValue(bool* pbool){*pbool=value;}
64 void GetParameterValue(int* pinteger){ISSMERROR("Bool param of enum %i (%s) cannot return an integer",enum_type,EnumAsString(enum_type));}
65 void GetParameterValue(double* pdouble){ISSMERROR("Bool param of enum %i (%s) cannot return a double",enum_type,EnumAsString(enum_type));}
66 void GetParameterValue(char** pstring){ISSMERROR("Bool param of enum %i (%s) cannot return a string",enum_type,EnumAsString(enum_type));}
67 void GetParameterValue(char*** pstringarray,int* pM){ISSMERROR("Bool param of enum %i (%s) cannot return a string arrayl",enum_type,EnumAsString(enum_type));}
68 void GetParameterValue(double** pdoublearray,int* pM){ISSMERROR("Bool param of enum %i (%s) cannot return a double array",enum_type,EnumAsString(enum_type));}
69 void GetParameterValue(double** pdoublearray,int* pM, int* pN){ISSMERROR("Bool param of enum %i (%s) cannot return a double array",enum_type,EnumAsString(enum_type));}
70 void GetParameterValue(Vec* pvec){ISSMERROR("Bool param of enum %i (%s) cannot return a Vec",enum_type,EnumAsString(enum_type));}
71 void GetParameterValue(Mat* pmat){ISSMERROR("Bool param of enum %i (%s) cannot return a Mat",enum_type,EnumAsString(enum_type));}
72 char* GetParameterName(void);
73 void Process(double* partition,int numberofvertices);
74 #ifdef _SERIAL_
75 void SetMatlabField(mxArray* dataref);
76 #endif
77 /*}}}*/
78};
79#endif /* _BOOLPARAM_H */
Note: See TracBrowser for help on using the repository browser.