-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAbstractPacemaker.vdmsl
58 lines (46 loc) · 1.18 KB
/
AbstractPacemaker.vdmsl
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
types
Trace = seq of [Event];
Event = <A> | <V>;
state Pacemaker of
aperiod : nat
vdelay : nat
init p == p = mk_Pacemaker(15,10)
end
operations
Init: nat * nat ==> ()
Init(aperi,vdel) ==
(aperiod := aperi;
vdelay := vdel);
IdealHeart: () ==> Trace
IdealHeart() ==
return [ if i mod aperiod = 1
then <A>
elseif i mod aperiod = vdelay + 1
then <V>
else nil
| i in set {1,...,100}];
FaultyHeart() tr : Trace
post len tr = 100 and
Periodic(tr,<A>,aperiod) and
not Periodic(tr,<V>,aperiod);
functions
Periodic: Trace * Event * nat1 -> bool
Periodic(tr,e,p) ==
forall t in set inds tr &
(tr(t) = e) =>
(t + p <= len tr =>
((tr(t+p) = e and
forall i in set {t+1, ..., t+p-1} & tr(i) <> e))
and
(t + p > len tr =>
forall i in set {t+1, ..., len tr} & tr(i) <> e));
values
wrongTR: Trace = [<A>, nil, <V>, nil, nil, <A>, nil, nil, nil, nil ];
operations
Pace: Trace * nat1 * nat1 ==> Trace
Pace(tr,aperi,vdel) ==
return [nil] ^
[ if (i mod aperi = vdel + 1) and tr(i) <> <V>
then <V>
else nil
| i in set inds tl tr];