src/HOL/IOA/ABP/Sender.thy
author clasohm
Wed, 21 Jun 1995 15:47:10 +0200
changeset 1151 c820b3cc3df0
parent 1139 993e475e70e2
child 1376 92f83b9d17e1
permissions -rw-r--r--
removed \...\ inside strings
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1139
993e475e70e2 *** empty log message ***
mueller
parents: 1050
diff changeset
     1
(*  Title:      HOL/IOA/example/Sender.thy
1050
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     2
    ID:         $Id$
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     3
    Author:     Tobias Nipkow & Konrad Slind
1139
993e475e70e2 *** empty log message ***
mueller
parents: 1050
diff changeset
     4
    Copyright   1994  TU Muenchen
1050
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     5
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     6
The implementation: sender
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     7
*)
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     8
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     9
Sender = IOA + Action + List + Lemmas +
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    10
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    11
types
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    12
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    13
'm sender_state = "'m list  *  bool"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    14
(*                messages     Alternating Bit   *)
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    15
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    16
consts
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    17
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    18
sender_asig   :: "'m action signature"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    19
sender_trans  :: "('m action, 'm sender_state)transition set"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    20
sender_ioa    :: "('m action, 'm sender_state)ioa"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    21
sq            :: "'m sender_state => 'm list"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    22
sbit          :: "'m sender_state => bool"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    23
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    24
defs
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    25
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    26
sq_def       "sq == fst"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    27
sbit_def     "sbit == snd"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    28
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    29
sender_asig_def
1151
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    30
  "sender_asig == ((UN m. {S_msg(m)}) Un (UN b. {R_ack(b)}),       
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    31
                  UN pkt. {S_pkt(pkt)},                   
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    32
                  {})"
1050
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    33
1151
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    34
sender_trans_def "sender_trans ==                                     
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    35
 {tr. let s = fst(tr);                                               
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    36
          t = snd(snd(tr))                                           
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    37
      in case fst(snd(tr))                                           
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    38
      of   
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    39
      Next     => if sq(s)=[] then t=s else False |                
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    40
      S_msg(m) => sq(t)=sq(s)@[m]   &                                
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    41
                  sbit(t)=sbit(s)  |                                 
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    42
      R_msg(m) => False |                                            
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    43
      S_pkt(pkt) => sq(s) ~= []  &                                   
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    44
		     hdr(pkt) = sbit(s)      &                        
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    45
                    msg(pkt) = hd(sq(s))    &                   
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    46
                    sq(t) = sq(s)           &                        
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    47
                    sbit(t) = sbit(s) |                              
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    48
      R_pkt(pkt) => False |                                          
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    49
      S_ack(b)   => False |                                          
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    50
      R_ack(b)   => if b = sbit(s) then                              
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    51
		     sq(t)=tl(sq(s)) & sbit(t)=(~sbit(s)) else   
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    52
		     sq(t)=sq(s) & sbit(t)=sbit(s)}"
1050
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    53
1151
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    54
sender_ioa_def "sender_ioa == 
c820b3cc3df0 removed \...\ inside strings
clasohm
parents: 1139
diff changeset
    55
 (sender_asig, {([],True)}, sender_trans)"
1050
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    56
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    57
end