-
Notifications
You must be signed in to change notification settings - Fork 1
/
AdjustGXAssignmentProcess.cpp
75 lines (53 loc) · 1.36 KB
/
AdjustGXAssignmentProcess.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#include "libecs.hpp"
#include "Process.hpp"
USE_LIBECS;
LIBECS_DM_CLASS( AdjustGXAssignmentProcess, Process )
{
public:
LIBECS_DM_OBJECT( AdjustGXAssignmentProcess, Process )
{
INHERIT_PROPERTIES( Process );
PROPERTYSLOT_SET_GET( Real, k );
}
AdjustGXAssignmentProcess()
:
k( 0.0 )
{
// do nothing
}
SIMPLE_SET_GET_METHOD( Real, k );
virtual void initialize()
{
Process::initialize();
state = getVariableReference( "state" ).getVariable();
prev = getVariableReference( "prev" ).getVariable();
I = getVariableReference( "I" ).getVariable();
target = getVariableReference( "target" ).getVariable();
GX = getVariableReference( "GX" ).getVariable();
prev->setValue( target->getMolarConc());
_target0 = target->getMolarConc();
}
virtual void fire()
{
if (( I->getValue() <= 0.0 ) && ( state->getValue() > 0.0 ))
{
_GX_new = GX->getValue() - ( target->getMolarConc() - _target0 ) * k;
if ( _GX_new < 0.1 ) _GX_new = 0.1;
GX->setValue( _GX_new );
state->setValue( -1.0 );
prev->setValue( target->getMolarConc());
}
else if (( I->getValue() > 0.0 ) && ( state->getValue() < 0.0 )) state->setValue( 1.0 );
}
protected:
Variable* state;
Variable* prev;
Variable* I;
Variable* target;
Variable* GX;
Real k;
private:
Real _target0;
Real _GX_new;
};
LIBECS_DM_INIT( AdjustGXAssignmentProcess, Process );