src/HOL/IOA/NTP/Impl.ML
author clasohm
Tue, 30 Jan 1996 15:24:36 +0100
changeset 1465 5d7a7e439cec
parent 1328 9a449a91425d
child 1894 c2c8279d40f0
permissions -rw-r--r--
expanded tabs
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/IOA/NTP/Impl.ML
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
     2
    ID:         $Id$
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
     3
    Author:     Tobias Nipkow & Konrad Slind
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
     4
    Copyright   1994  TU Muenchen
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
     5
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
     6
The implementation --- Invariants
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
     7
*)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
     8
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
     9
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    10
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    11
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    12
open Abschannel Impl;
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    13
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    14
val impl_ioas =
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    15
  [Impl.impl_def,
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    16
   Sender.sender_ioa_def, 
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    17
   Receiver.receiver_ioa_def, 
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    18
   srch_ioa_thm RS eq_reflection,
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    19
   rsch_ioa_thm RS eq_reflection];
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    20
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    21
val transitions = [Sender.sender_trans_def, Receiver.receiver_trans_def,
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    22
                   srch_trans_def, rsch_trans_def];
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    23
 
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    24
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
    25
Addsimps [ioa_triple_proj, starts_of_par, trans_of_par4,
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
    26
          in_sender_asig, in_receiver_asig, in_srch_asig,
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    27
          in_rsch_asig];
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    28
Addcongs [let_weak_cong];
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    29
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    30
goal Impl.thy
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    31
  "fst(x) = sen(x)            & \
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    32
\  fst(snd(x)) = rec(x)       & \
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    33
\  fst(snd(snd(x))) = srch(x) & \
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    34
\  snd(snd(snd(x))) = rsch(x)";
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
    35
by(simp_tac (!simpset addsimps
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    36
             [sen_def,rec_def,srch_def,rsch_def]) 1);
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
    37
Addsimps [result()];
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    38
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    39
goal Impl.thy "a:actions(sender_asig)   \
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    40
\            | a:actions(receiver_asig) \
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    41
\            | a:actions(srch_asig)     \
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    42
\            | a:actions(rsch_asig)";
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    43
  by(Action.action.induct_tac "a" 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    44
  by(ALLGOALS (Simp_tac));
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
    45
Addsimps [result()];
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    46
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    47
Delsimps [split_paired_All];
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    48
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    49
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    50
(* Three Simp_sets in different sizes 
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    51
----------------------------------------------
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    52
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    53
1) !simpset does not unfold the transition relations 
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    54
2) ss unfolds transition relations 
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    55
3) renname_ss unfolds transitions and the abstract channel *)
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    56
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    57
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    58
val ss = (!simpset addcongs [if_weak_cong]
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    59
                   addsimps transitions);     
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    60
val rename_ss = (ss addsimps unfold_renaming);
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    61
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    62
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    63
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    64
val tac     = asm_simp_tac ((ss addcongs [conj_cong]) 
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    65
                            setloop (split_tac [expand_if]));
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    66
val tac_ren = asm_simp_tac ((rename_ss addcongs [conj_cong]) 
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    67
                            setloop (split_tac [expand_if]));
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    68
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    69
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    70
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    71
(* INVARIANT 1 *)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    72
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    73
goalw Impl.thy impl_ioas "invariant impl_ioa inv1";
1465
5d7a7e439cec expanded tabs
clasohm
parents: 1328
diff changeset
    74
by (rtac invariantI 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    75
by(asm_full_simp_tac (!simpset
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    76
   addsimps [inv1_def, hdr_sum_def, Sender.srcvd_def,
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
    77
             Sender.ssent_def, Receiver.rsent_def,Receiver.rrcvd_def]) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    78
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    79
by(simp_tac (!simpset delsimps [trans_of_par4]
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    80
                addsimps [fork_lemma,inv1_def]) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    81
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    82
(* Split proof in two *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    83
by (rtac conjI 1); 
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    84
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    85
(* First half *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    86
by(asm_full_simp_tac (!simpset addsimps [Impl.inv1_def]) 1);
1465
5d7a7e439cec expanded tabs
clasohm
parents: 1328
diff changeset
    87
by (rtac Action.action.induct 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    88
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    89
by (EVERY1[tac, tac, tac, tac]);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    90
by (tac 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    91
by (tac_ren 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    92
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    93
(* 5 + 1 *)
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
    94
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    95
by (tac 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
    96
by (tac_ren 1);
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
    97
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    98
(* 4 + 1 *)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
    99
by(EVERY1[tac, tac, tac, tac]);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   100
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   101
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   102
(* Now the other half *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   103
by(asm_full_simp_tac (!simpset addsimps [Impl.inv1_def]) 1);
1465
5d7a7e439cec expanded tabs
clasohm
parents: 1328
diff changeset
   104
by (rtac Action.action.induct 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   105
by(EVERY1[tac, tac]);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   106
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   107
(* detour 1 *)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   108
by (tac 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   109
by (tac_ren 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   110
by (rtac impI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   111
by (REPEAT (etac conjE 1));
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   112
by (asm_simp_tac (!simpset addsimps [hdr_sum_def, Multiset.count_def,
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   113
                               Multiset.countm_nonempty_def]
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   114
                     setloop (split_tac [expand_if])) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   115
(* detour 2 *)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   116
by (tac 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   117
by (tac_ren 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   118
by (rtac impI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   119
by (REPEAT (etac conjE 1));
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   120
by (asm_full_simp_tac (!simpset addsimps [Impl.hdr_sum_def, 
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   121
                                         Multiset.count_def,
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   122
                                         Multiset.countm_nonempty_def,
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   123
                                         Multiset.delm_nonempty_def,
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   124
                                         left_plus_cancel,
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   125
                                         left_plus_cancel_inside_succ,
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   126
                                         unzero_less]
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   127
                               setloop (split_tac [expand_if])) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   128
by (rtac allI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   129
by (rtac conjI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   130
by (rtac impI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   131
by (hyp_subst_tac 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   132
by (rtac (pred_suc RS mp RS sym RS iffD2) 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   133
by (dtac less_le_trans 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   134
by (cut_facts_tac [rewrite_rule[Packet.hdr_def]
1465
5d7a7e439cec expanded tabs
clasohm
parents: 1328
diff changeset
   135
                   eq_packet_imp_eq_hdr RS countm_props] 1);;
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   136
by (assume_tac 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   137
by (assume_tac 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   138
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   139
by (rtac (countm_done_delm RS mp RS sym) 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   140
by (rtac refl 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   141
by (asm_simp_tac (!simpset addsimps [Multiset.count_def]) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   142
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   143
by (rtac impI 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   144
by (asm_full_simp_tac (!simpset addsimps [neg_flip]) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   145
by (hyp_subst_tac 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   146
by (rtac countm_spurious_delm 1);
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   147
by (Simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   148
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   149
by (EVERY1[tac, tac, tac, tac, tac, tac]);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   150
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   151
qed "inv1";
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   152
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   153
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   154
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   155
(* INVARIANT 2 *)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   156
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   157
  goal Impl.thy "invariant impl_ioa inv2";
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   158
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   159
  by (rtac invariantI1 1); 
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   160
  (* Base case *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   161
  by (asm_full_simp_tac (!simpset addsimps (inv2_def ::
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   162
                          (receiver_projections 
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   163
                           @ sender_projections @ impl_ioas)))
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   164
      1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   165
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   166
  by (asm_simp_tac (!simpset addsimps impl_ioas) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   167
  by (Action.action.induct_tac "a" 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   168
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   169
  (* 10 cases. First 4 are simple, since state doesn't change *)
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   170
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   171
val tac2 = asm_full_simp_tac (ss addsimps [inv2_def]);
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   172
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   173
  (* 10 - 7 *)
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   174
  by (EVERY1[tac2,tac2,tac2,tac2]);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   175
  (* 6 *)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   176
  by(forward_tac [rewrite_rule [Impl.inv1_def]
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   177
                               (inv1 RS invariantE) RS conjunct1] 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   178
  (* 6 - 5 *)
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   179
  by (EVERY1[tac2,tac2]);
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   180
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   181
  (* 4 *)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   182
  by (forward_tac [rewrite_rule [Impl.inv1_def]
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   183
                                (inv1 RS invariantE) RS conjunct1] 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   184
  by (tac2 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   185
  by (fast_tac (HOL_cs addDs [add_leD1,leD]) 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   186
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   187
  (* 3 *)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   188
  by (forward_tac [rewrite_rule [Impl.inv1_def] (inv1 RS invariantE)] 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   189
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   190
  by (tac2 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   191
  by (fold_tac [rewrite_rule [Packet.hdr_def]Impl.hdr_sum_def]);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   192
  by (fast_tac (HOL_cs addDs [add_leD1,leD]) 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   193
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   194
  (* 2 *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   195
  by (tac2 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   196
  by(forward_tac [rewrite_rule [Impl.inv1_def]
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   197
                               (inv1 RS invariantE) RS conjunct1] 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   198
  by (rtac impI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   199
  by (rtac impI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   200
  by (REPEAT (etac conjE 1));
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   201
  by (dres_inst_tac [("k","count (rsch s) (~sbit(sen s))")] 
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   202
                     (standard(leq_add_leq RS mp)) 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   203
  by (Asm_full_simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   204
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   205
  (* 1 *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   206
  by (tac2 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   207
  by(forward_tac [rewrite_rule [Impl.inv1_def]
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   208
                               (inv1 RS invariantE) RS conjunct2] 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   209
  by (rtac impI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   210
  by (rtac impI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   211
  by (REPEAT (etac conjE 1));
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   212
  by (fold_tac  [rewrite_rule[Packet.hdr_def]Impl.hdr_sum_def]);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   213
  by (dres_inst_tac [("k","hdr_sum (srch s) (sbit(sen s))")] 
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   214
                     (standard(leq_add_leq RS mp)) 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   215
  by (Asm_full_simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   216
qed "inv2";
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   217
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   218
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   219
(* INVARIANT 3 *)
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   220
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   221
goal Impl.thy "invariant impl_ioa inv3";
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   222
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   223
  by (rtac invariantI 1); 
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   224
  (* Base case *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   225
  by (asm_full_simp_tac (!simpset addsimps 
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   226
                    (Impl.inv3_def :: (receiver_projections 
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   227
                                       @ sender_projections @ impl_ioas))) 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   228
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   229
  by (asm_simp_tac (!simpset addsimps impl_ioas) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   230
  by (Action.action.induct_tac "a" 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   231
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   232
val tac3 = asm_full_simp_tac (ss addsimps [inv3_def] 
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   233
                              setloop (split_tac [expand_if]));
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   234
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   235
  (* 10 - 8 *)
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   236
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   237
  by (EVERY1[tac3,tac3,tac3]);
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   238
 
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   239
  by (tac_ren 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   240
  by (strip_tac  1 THEN REPEAT (etac conjE 1));
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   241
  by (hyp_subst_tac 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   242
  by (etac exE 1);
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   243
  by (Asm_full_simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   244
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   245
  (* 7 *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   246
  by (tac3 1);
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   247
  by (tac_ren 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   248
  by (fast_tac HOL_cs 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   249
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   250
  (* 6 - 3 *)
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   251
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   252
  by (EVERY1[tac3,tac3,tac3,tac3]);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   253
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   254
  (* 2 *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   255
  by (asm_full_simp_tac ss 1);
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   256
  by (simp_tac (!simpset addsimps [inv3_def]) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   257
  by (strip_tac  1 THEN REPEAT (etac conjE 1));
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   258
  by (rtac (imp_or_lem RS iffD2) 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   259
  by (rtac impI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   260
  by (forward_tac [rewrite_rule [Impl.inv2_def] (inv2 RS invariantE)] 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   261
  by (Asm_full_simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   262
  by (REPEAT (etac conjE 1));
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   263
  by (res_inst_tac [("j","count (ssent(sen s)) (~sbit(sen s))"),
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   264
                    ("k","count (rsent(rec s)) (sbit(sen s))")] le_trans 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   265
  by (forward_tac [rewrite_rule [inv1_def]
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   266
                                (inv1 RS invariantE) RS conjunct2] 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   267
  by (asm_full_simp_tac (!simpset addsimps
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   268
                         [hdr_sum_def, Multiset.count_def]) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   269
  by (rtac (less_eq_add_cong RS mp RS mp) 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   270
  by (rtac countm_props 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   271
  by (Simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   272
  by (rtac countm_props 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   273
  by (Simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   274
  by (assume_tac 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   275
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   276
  (* 1 *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   277
  by (tac3 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   278
  by (strip_tac  1 THEN REPEAT (etac conjE 1));
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   279
  by (rtac (imp_or_lem RS iffD2) 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   280
  by (rtac impI 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   281
  by (forward_tac [rewrite_rule [Impl.inv2_def] (inv2 RS invariantE)] 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   282
  by (Asm_full_simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   283
  by (REPEAT (etac conjE 1));
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   284
  by (dtac mp 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   285
  by (assume_tac 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   286
  by (etac allE 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   287
  by (dtac (imp_or_lem RS iffD1) 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   288
  by (dtac mp 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   289
  by (assume_tac 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   290
  by (assume_tac 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   291
qed "inv3";
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   292
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   293
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   294
(* INVARIANT 4 *)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   295
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   296
goal Impl.thy "invariant impl_ioa inv4";
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   297
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   298
  by (rtac invariantI 1); 
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   299
  (* Base case *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   300
  by (asm_full_simp_tac (!simpset addsimps 
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   301
                    (Impl.inv4_def :: (receiver_projections 
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   302
                                       @ sender_projections @ impl_ioas))) 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   303
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   304
  by (asm_simp_tac (!simpset addsimps impl_ioas) 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   305
  by (Action.action.induct_tac "a" 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   306
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   307
val tac4 =  asm_full_simp_tac (ss addsimps [inv4_def]
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   308
                              setloop (split_tac [expand_if]));
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   309
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   310
  (* 10 - 2 *)
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   311
  
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   312
  by (EVERY1[tac4,tac4,tac4,tac4,tac4,tac4,tac4,tac4,tac4]);
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   313
 
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   314
 (* 2 b *)
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   315
 
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   316
  by (strip_tac  1 THEN REPEAT (etac conjE 1));
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   317
  by(forward_tac [rewrite_rule [Impl.inv2_def]
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   318
                               (inv2 RS invariantE)] 1);
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   319
  by (tac4 1);
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   320
  by (Asm_full_simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   321
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   322
  (* 1 *)
1328
9a449a91425d *** empty log message ***
mueller
parents: 1266
diff changeset
   323
  by (tac4 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   324
  by (strip_tac  1 THEN REPEAT (etac conjE 1));
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   325
  by (rtac ccontr 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   326
  by(forward_tac [rewrite_rule [Impl.inv2_def]
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   327
                               (inv2 RS invariantE)] 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   328
  by(forward_tac [rewrite_rule [Impl.inv3_def]
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   329
                               (inv3 RS invariantE)] 1);
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   330
  by (Asm_full_simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   331
  by (eres_inst_tac [("x","m")] allE 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   332
  by (dtac less_le_trans 1);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   333
  by (dtac (left_add_leq RS mp) 1);
1266
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   334
  by (Asm_full_simp_tac 1);
3ae9fe3c0f68 added local simpsets
clasohm
parents: 1051
diff changeset
   335
  by (Asm_full_simp_tac 1);
1051
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   336
qed "inv4";
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   337
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   338
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   339
(* rebind them *)
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   340
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   341
val inv1 = rewrite_rule [Impl.inv1_def] (inv1 RS invariantE);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   342
val inv2 = rewrite_rule [Impl.inv2_def] (inv2 RS invariantE);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   343
val inv3 = rewrite_rule [Impl.inv3_def] (inv3 RS invariantE);
4fcd0638e61d Directory example is now called NTP
nipkow
parents:
diff changeset
   344
val inv4 = rewrite_rule [Impl.inv4_def] (inv4 RS invariantE);