IOA/meta_theory/Solve.ML
author clasohm
Wed, 02 Nov 1994 11:50:09 +0100
changeset 156 fd1be45b64bf
child 168 44ff2275d44f
permissions -rw-r--r--
added IOA to isabelle/HOL
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
156
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
     1
open Solve IOA Asig;
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
     2
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
     3
val SS = SS addsimps [mk_behaviour_thm,trans_in_actions];
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
     4
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
     5
goalw Solve.thy [is_weak_pmap_def,behaviours_def]
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
     6
  "!!f. [| IOA(C); IOA(A); externals(asig_of(C)) = externals(asig_of(A)); \
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
     7
\          is_weak_pmap(f,C,A) |] ==> behaviours(C) <= behaviours(A)";
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
     8
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
     9
  by (simp_tac(SS addsimps [has_behaviour_def])1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    10
  by (safe_tac set_cs);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    11
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    12
  (* give execution of abstract automata *)
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    13
  by (res_inst_tac[("x","<mk_behaviour(A,fst(ex)),%i.f(snd(ex,i))>")] bexI 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    14
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    15
  (* Behaviours coincide *)
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    16
  by (asm_simp_tac (SS addsimps [mk_behaviour_def,filter_oseq_idemp])1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    17
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    18
  (* Use lemma *)
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    19
  by (forward_tac [states_of_exec_reachable] 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    20
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    21
  (* Now show that it's an execution *)
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    22
  by (asm_full_simp_tac(SS addsimps [executions_def]) 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    23
  by (safe_tac set_cs);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    24
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    25
  (* Start states map to start states *)
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    26
  by (dtac bspec 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    27
  by (atac 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    28
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    29
  (* Show that it's an execution fragment *)
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    30
  by (asm_full_simp_tac (SS addsimps [is_execution_fragment_def])1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    31
  by (safe_tac HOL_cs);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    32
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    33
  (* Cases on whether action is external or not (basically) *)
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    34
  (* 1 *)
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    35
  by (eres_inst_tac [("x","snd(ex,n)")] allE 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    36
  by (eres_inst_tac [("x","snd(ex,Suc(n))")] allE 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    37
  by (eres_inst_tac [("x","aa")] allE 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    38
  by (asm_full_simp_tac SS 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    39
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    40
  (* 2 *)
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    41
  by (eres_inst_tac [("x","snd(ex,n)")] allE 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    42
  by (eres_inst_tac [("x","snd(ex,Suc(n))")] allE 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    43
  by (eres_inst_tac [("x","a")] allE 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    44
  by (asm_full_simp_tac SS 1);
fd1be45b64bf added IOA to isabelle/HOL
clasohm
parents:
diff changeset
    45
val trace_inclusion = result();