mirror of
https://github.com/achlipala/frap.git
synced 2025-01-05 23:54:14 +00:00
Fancier set simplification
This commit is contained in:
parent
32ad7c8e8e
commit
a583e1d0d4
1 changed files with 28 additions and 0 deletions
28
Frap.v
28
Frap.v
|
@ -43,6 +43,34 @@ Ltac invert0 e := invert e; fail.
|
|||
Ltac invert1 e := invert0 e || (invert e; []).
|
||||
Ltac invert2 e := invert1 e || (invert e; [|]).
|
||||
|
||||
Ltac maps_neq :=
|
||||
match goal with
|
||||
| [ H : ?m1 = ?m2 |- _ ] =>
|
||||
let rec recur E :=
|
||||
match E with
|
||||
| ?E' $+ (?k, _) =>
|
||||
(apply (f_equal (fun m => m $? k)) in H; simpl in *; autorewrite with core in *; simpl in *; congruence)
|
||||
|| recur E'
|
||||
end in
|
||||
recur m1 || recur m2
|
||||
end.
|
||||
|
||||
Ltac fancy_neq :=
|
||||
repeat match goal with
|
||||
| _ => maps_neq
|
||||
| [ H : _ = _ |- _ ] => invert H
|
||||
end.
|
||||
|
||||
Ltac removeDups :=
|
||||
match goal with
|
||||
| [ |- context[constant ?ls] ] =>
|
||||
someMatch ls;
|
||||
erewrite (@removeDups_ok _ ls)
|
||||
by repeat (apply RdNil
|
||||
|| (apply RdNew; [ simpl; intuition (congruence || solve [ fancy_neq ]) | ])
|
||||
|| (apply RdDup; [ simpl; intuition congruence | ]))
|
||||
end.
|
||||
|
||||
Ltac simplify := repeat (unifyTails; pose proof I);
|
||||
repeat match goal with
|
||||
| [ H : True |- _ ] => clear H
|
||||
|
|
Loading…
Reference in a new issue