-
Notifications
You must be signed in to change notification settings - Fork 1
/
IKplAssignmentProcess.cpp
79 lines (59 loc) · 1.58 KB
/
IKplAssignmentProcess.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
75
76
77
78
#include "libecs.hpp"
#include "Process.hpp"
USE_LIBECS;
LIBECS_DM_CLASS( IKplAssignmentProcess, Process )
{
public:
LIBECS_DM_OBJECT( IKplAssignmentProcess, Process )
{
INHERIT_PROPERTIES( Process );
PROPERTYSLOT_SET_GET( Real, amplitude );
PROPERTYSLOT_SET_GET( Real, constant );
PROPERTYSLOT_SET_GET( Real, power );
PROPERTYSLOT_SET_GET( Real, pOpen );
}
IKplAssignmentProcess()
:
amplitude( 8.333E-7 ),
constant( 5.4 ),
power( 0.16 ),
pOpen( 1.0 )
{
// do nothing
}
SIMPLE_SET_GET_METHOD( Real, amplitude );
SIMPLE_SET_GET_METHOD( Real, constant );
SIMPLE_SET_GET_METHOD( Real, power );
SIMPLE_SET_GET_METHOD( Real, pOpen );
virtual void initialize()
{
Process::initialize();
I = getVariableReference( "I" ).getVariable();
GX = getVariableReference( "GX" ).getVariable();
Cm = getVariableReference( "Cm" ).getVariable();
Vm = getVariableReference( "Vm" ).getVariable();
Ko = getVariableReference( "Ko" ).getVariable();
CFK = getVariableReference( "CFK" ).getVariable();
}
virtual void fire()
{
_Vm = Vm->getValue();
_Veff = ( _Vm == -3.0 ) ? 13.0077 : (( _Vm + 3.0 ) / ( 1.0 - exp( - ( _Vm + 3.0 ) / 13.0 )));
I->setValue( GX->getValue() * ( amplitude * pow(( Ko->getMolarConc() * 1000.0 / constant ), power )) * _Veff * CFK->getValue() * pOpen * Cm->getValue() );
}
protected:
Variable* I;
Variable* GX;
Variable* Cm;
Variable* Vm;
Variable* Ko;
Variable* CFK;
Real amplitude;
Real constant;
Real power;
Real pOpen;
private:
Real _Vm;
Real _Veff;
};
LIBECS_DM_INIT( IKplAssignmentProcess, Process );