| Who Cites while? | |
| while |
Def (M |= x,tr.P(x;tr) while Q(x;tr))
== (M |= x,x',tr,tr'.P(x;tr) |
| Thm* | |
| tla |
Def (M |= x,x',tr,tr'.R(x;x';tr;tr'))
== |
| Thm* | |
| append |
Def as @ bs == Case of as; nil |
|
Thm* | |
| initially |
Def (M |= initially x,tr.P(x;tr)) == |
| Thm* | |
| reachable_via |
Def (M -tr- > s) == |
| Thm* | |
| sm |
Def sm{i:l}() == da:Decl |
| Thm* sm{i:l}() | |
| trace_inv |
Def (M |= always s,t.P(s;t))
== |
| Thm* | |
| sm_action |
Def M.action == ( |
| Thm* | |
| sm_init | Def t.init == 1of(2of(2of(t))) |
|
Thm* | |
| trace_reachable |
Def trace_reachable(M;s;l;s')
== Case of l
nil |
|
Thm* | |
| sm_state | Def M.state == {M.ds} |
| Thm* | |
| sm_trans | Def t.trans == 2of(2of(2of(t))) |
|
Thm* | |
| record |
Def {d} == l:Label |
| Thm* | |
| sigma |
Def ( |
| Thm* | |
| decl |
Def Decl == Label |
| Thm* decl{i:l} | |
| sm_da | Def t.da == 1of(t) |
|
Thm* | |
| sm_ds | Def t.ds == 1of(2of(t)) |
|
Thm* | |
| pi2 | Def 2of(t) == t.2 |
|
Thm* | |
| pi1 | Def 1of(t) == t.1 |
| Thm* | |
| decl_type | Def decl_type(d;x) == d(x) |
| Thm* | |
| lbl |
Def Label == {p:Pattern| |
| Thm* Label | |
| ground_ptn |
Def ground_ptn(p)
== Case(p)
Case ptn_var(v) = >
false |
|
Thm* | |
| assert |
Def |
| Thm* | |
| ptn | Def Pattern == rec(T.ptn_con(T)) |
|
Thm* Pattern | |
| case_default | Def Default = > body(value,value) == body |
| band |
Def p |
| Thm* | |
| case_lbl_pair | Def Case ptn_pr( < x, y > ) = > body(x;y) cont(x1,z) == InjCase(x1; _. cont(z,z); x2. InjCase(x2; _. cont(z,z); x2@0. InjCase(x2@0; _. cont(z,z); x2@1. x2@1/x3,x2@2. body(x3;x2@2)))) |
| case_ptn_var |
Def Case ptn_var(x) = > body(x) cont(x1,z)
== ( |
| case | Def Case(value) body == body(value,value) |
| ptn_con |
Def ptn_con(T) == Atom+ |
| Thm* | |
| hd |
Def hd(l) == Case of l; nil |
|
Thm* | |
|
Thm* | |
| tl |
Def tl(l) == Case of l; nil |
|
Thm* | |
| case_inl | Def inl(x) = > body(x) cont(value,contvalue) == InjCase(value; x. body(x); _. cont(contvalue,contvalue)) |
| case_inr | Def inr(x) = > body(x) cont(value,contvalue) == InjCase(value; _. cont(contvalue,contvalue); x. body(x)) |
About: