summaryrefslogtreecommitdiff
path: root/test-suite/complexity
diff options
context:
space:
mode:
authorGravatar Samuel Mimram <smimram@debian.org>2008-07-25 15:12:53 +0200
committerGravatar Samuel Mimram <smimram@debian.org>2008-07-25 15:12:53 +0200
commita0cfa4f118023d35b767a999d5a2ac4b082857b4 (patch)
treedabcac548e299fee1da464c93b3dba98484f45b1 /test-suite/complexity
parent2281410e38ef99d025ea77194585a9bc019fdaa9 (diff)
Imported Upstream version 8.2~beta3+dfsgupstream/8.2.beta3+dfsg
Diffstat (limited to 'test-suite/complexity')
-rw-r--r--test-suite/complexity/injection.v113
-rw-r--r--test-suite/complexity/ring.v7
-rw-r--r--test-suite/complexity/ring2.v51
3 files changed, 171 insertions, 0 deletions
diff --git a/test-suite/complexity/injection.v b/test-suite/complexity/injection.v
new file mode 100644
index 00000000..eb01133e
--- /dev/null
+++ b/test-suite/complexity/injection.v
@@ -0,0 +1,113 @@
+(* This example, submitted by A. Appel, checks the efficiency of
+ injection (see bug #1173) *)
+(* Expected time < 1.50s *)
+
+Set Implicit Arguments.
+
+Record joinable (t: Type) : Type := Joinable {
+ is_empty: t -> Prop;
+ join: t -> t -> t -> Prop;
+ join_com: forall a b c, join a b c -> join b a c;
+ join_empty: forall e a b, is_empty e -> join e a b -> a=b;
+ exists_empty: forall a, exists e, is_empty e /\ join e a a;
+ join_empty2: forall a b c, join a b c -> is_empty c -> is_empty a;
+ join_empty3: forall e a, join e a a -> is_empty e;
+ join_assoc: forall a b c d e, join a b d -> join d c e ->
+ exists f, join b c f /\ join a f e;
+ join_eq: forall x y z z', join x y z -> join x y z' -> z = z';
+ cancellation: forall a1 a2 b c, join a1 b c -> join a2 b c -> a1=a2
+}.
+
+Record joinmap (key: Type) (t: Type) (j : joinable t) : Type
+ := Joinmap {
+ jm_t : Type;
+ jm_j : joinable jm_t;
+ lookup: jm_t -> key -> t;
+ prim : forall (f: key -> t) (e: t),
+ (forall k, j.(join) e (f k) (f k)) ->
+ jm_t;
+ join_rule: forall s1 s2 s,
+ jm_j.(join) s1 s2 s <->
+ forall x, j.(join) (lookup s1 x) (lookup s2 x) (lookup s x);
+ empty_rule: forall e x, jm_j.(is_empty) e -> j.(is_empty) (lookup e x);
+ prim_rule: forall f e pf k, lookup (prim f e pf) k = f k;
+ ext: forall s1 s2,
+ (forall x, lookup s1 x = lookup s2 x) <-> s1 = s2;
+ can_join: forall s1 s2,
+ (forall x, exists v,
+ j.(join) (lookup s1 x) (lookup s2 x) v) ->
+ exists s3, jm_j.(join) s1 s2 s3;
+ can_split: forall s1 s3,
+ (forall x, exists v,
+ j.(join) (lookup s1 x) v (lookup s3 x)) ->
+ exists s2, jm_j.(join) s1 s2 s3
+}.
+
+Parameter mkJoinmap : forall (key: Type) (t: Type) (j: joinable t),
+joinmap key j.
+
+Parameter ADMIT: forall p: Prop, p.
+Implicit Arguments ADMIT [p].
+
+Module Share.
+Parameter jb : joinable bool.
+Definition jm: joinmap nat jb := mkJoinmap nat jb.
+Definition t := jm.(jm_t).
+Definition j := jm.(jm_j).
+Parameter nonempty: t -> Prop.
+End Share.
+
+Section Own.
+
+Variable inv : Type.
+
+Inductive own : Type :=
+ | NO
+ | VAL' : forall sh, Share.nonempty sh -> own
+ | LK : forall sh, Share.nonempty sh -> Share.t -> inv -> own
+ | CT : forall sh, Share.nonempty sh -> own
+ | FUN: forall sh, Share.nonempty sh -> inv -> own.
+
+Definition own_join (a b c: own) : Prop :=
+ match a , b , c with
+ | NO , _ , _ => b=c
+ | _ , NO , _ => a=c
+ | VAL' sa _ , VAL' sb _, VAL' sc _ => Share.j.(join) sa sb sc
+ | LK sa pa ha fa, LK sb pb hb fb, LK sc pc hc fc =>
+ Share.j.(join) sa sb sc /\
+ Share.j.(join) ha hb hc /\
+ fa=fc /\
+ fb=fc
+ | CT sa pa , CT sb pb, CT sc pc => Share.j.(join) sa sb sc
+ | FUN sa pa fa, FUN sb pb fb, FUN sc pc fc =>
+ Share.j.(join) sa sb sc /\ fa=fc /\ fb=fc
+ | _ , _ , _ => False
+ end.
+
+Definition own_is_empty (a: own) := a=NO.
+
+Definition jown : joinable own :=
+ Joinable own_is_empty own_join
+ ADMIT ADMIT ADMIT ADMIT ADMIT ADMIT ADMIT ADMIT .
+End Own.
+
+Fixpoint sinv (n: nat) : Type :=
+ match n with
+ | O => unit
+ | S n => prodT (sinv n) (own (sinv n) -> unit -> Prop)
+ end.
+
+Parameter address: Set.
+
+Definition jm (n: nat) := mkJoinmap address (jown (sinv n)).
+
+Definition worldfun (n: nat) := (jm n).(jm_t).
+
+Inductive world : Type :=
+ mk_world: forall n, worldfun n -> world.
+
+Lemma test: forall n1 w1 n2 w2, mk_world n1 w1 = mk_world n2 w2 ->
+ n1 = n2.
+Proof.
+intros.
+Time injection H.
diff --git a/test-suite/complexity/ring.v b/test-suite/complexity/ring.v
new file mode 100644
index 00000000..5a541bc2
--- /dev/null
+++ b/test-suite/complexity/ring.v
@@ -0,0 +1,7 @@
+(* This example, checks the efficiency of the abstract machine used by ring *)
+(* Expected time < 1.00s *)
+
+Require Import ZArith.
+Open Scope Z_scope.
+Goal forall a, a+a+a+a+a+a+a+a+a+a+a+a+a = a*13.
+Time intro; ring.
diff --git a/test-suite/complexity/ring2.v b/test-suite/complexity/ring2.v
new file mode 100644
index 00000000..9f9685dd
--- /dev/null
+++ b/test-suite/complexity/ring2.v
@@ -0,0 +1,51 @@
+(* This example, checks the efficiency of the abstract machine used by ring *)
+(* Expected time < 1.00s *)
+
+Require Import BinInt.
+
+Definition Zplus x y :=
+match x with
+| 0%Z => y
+| Zpos x' =>
+ match y with
+ | 0%Z => x
+ | Zpos y' => Zpos (x' + y')
+ | Zneg y' =>
+ match (x' ?= y')%positive Eq with
+ | Eq => 0%Z
+ | Lt => Zneg (y' - x')
+ | Gt => Zpos (x' - y')
+ end
+ end
+| Zneg x' =>
+ match y with
+ | 0%Z => x
+ | Zpos y' =>
+ match (x' ?= y')%positive Eq with
+ | Eq => 0%Z
+ | Lt => Zpos (y' - x')
+ | Gt => Zneg (x' - y')
+ end
+ | Zneg y' => Zneg (x' + y')
+ end
+end.
+
+Require Import Ring.
+
+Lemma Zth : ring_theory Z0 (Zpos xH) Zplus Zmult Zminus Zopp (@eq Z).
+Admitted.
+
+Ltac Zcst t :=
+ match isZcst t with
+ true => t
+ | _ => constr:NotConstant
+ end.
+
+Add Ring Zr : Zth
+ (decidable Zeqb_ok, constants [Zcst]).
+
+Open Scope Z_scope.
+Infix "+" := Zplus : Z_scope.
+
+Goal forall a, a+a+a+a+a+a+a+a+a+a+a+a+a = a*13.
+Time intro; ring.