Skip to content

Commit

Permalink
Add case_elim thm for nterm
Browse files Browse the repository at this point in the history
  • Loading branch information
IlmariReissumies committed Nov 10, 2023
1 parent 896b121 commit 75db380
Showing 1 changed file with 18 additions and 0 deletions.
18 changes: 18 additions & 0 deletions examples/algorithms/unification/triangular/nominal/ntermScript.sml
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,23 @@ val nterm_case_eq = Q.store_thm(
‘∀p. p == c2 <=> p == c1’ suffices_by simp[] >>
metis_tac[permeq_def]);

val nterm_case_elim = Q.store_thm(
"nterm_case_elim",
‘∀f. (f(nterm_CASE n nmf sf tf pf cf) ⇔
(∃a. (n = Nom a) ∧ f(nmf a)) ∨
(∃p w. (n = Sus p w) ∧ f(sf (@p'. p' == p) w)) ∨
(∃a t. (n = Tie a t) ∧ f(tf a t)) ∨
(∃t1 t2. (n = nPair t1 t2) ∧ f(pf t1 t2)) ∨
(∃c. (n = nConst c) ∧ f(cf c)))’,
strip_tac >>
Q.ISPEC_THEN ‘n’ STRUCT_CASES_TAC nterm_nchotomy >>
simp[nterm_case_rewrites, Sus_case1] >> eq_tac >> rw[]
>- (first_x_assum $ irule_at $ Pos last >> rw[]) >>
pop_assum mp_tac >>
rename [‘_ (_ (@p'. p' == c1) _) ⇒ _(_ (@p'. p' == c2) _)’] >>
‘∀p. p == c2 <=> p == c1’ suffices_by simp[] >>
metis_tac[permeq_def]);

local open TypeBase TypeBasePure Drule
in
val _ = export [
Expand All @@ -268,6 +285,7 @@ val _ = export [
in n::Sus_case1::rest end),
case_cong = nterm_case_cong,
case_eq = nterm_case_eq,
case_elim = nterm_case_elim,
nchotomy = nterm_nchotomy,
size = SOME (``nterm_size``,ORIG nterm_size_def),
encode = NONE,
Expand Down

0 comments on commit 75db380

Please sign in to comment.