src/HOL/IOA/ABP/Abschannel_finite.thy
author lcp
Tue, 25 Apr 1995 11:14:03 +0200
changeset 1072 0140ff702b23
parent 1050 0c36c6a52a1d
child 1138 82fd99d5a6ff
permissions -rw-r--r--
updated version
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1050
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/IOA/ABP/Abschannel_finite.thy
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:     Olaf Mueller
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     4
    Copyright   1995  TU Muenchen
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     5
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
     6
The transmission channel -- finite version
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
Abschannel_finite = Abschannel+ IOA + Action + Lemmas + List +
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    10
 
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    11
consts
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    12
 
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    13
ch_fin_asig  :: "'a act signature"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    14
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    15
ch_fin_trans :: "('a act, 'a list)transition set"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    16
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    17
ch_fin_ioa   :: "('a act, 'a list)ioa"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    18
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    19
srch_fin_asig, 
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    20
rsch_fin_asig  :: "'m action signature"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    21
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    22
srch_fin_trans :: "('m action, 'm packet list)transition set"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    23
rsch_fin_trans :: "('m action, bool list)transition set"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    24
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    25
srch_fin_ioa   :: "('m action, 'm packet list)ioa"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    26
rsch_fin_ioa   :: "('m action, bool list)ioa"   
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    27
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    28
reverse        :: "'a list => 'a list"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    29
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    30
primrec
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    31
  reverse List.list  
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    32
  reverse_Nil  "reverse([]) = []"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    33
  reverse_Cons "reverse(x#xs) =  reverse(xs)@[x]"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    34
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    35
defs
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    36
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    37
srch_fin_asig_def "srch_fin_asig == asig_of(srch_fin_ioa)"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    38
rsch_fin_asig_def "rsch_fin_asig == asig_of(rsch_fin_ioa)"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    39
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    40
srch_fin_trans_def "srch_fin_trans == trans_of(srch_fin_ioa)"  
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    41
rsch_fin_trans_def "rsch_fin_trans == trans_of(rsch_fin_ioa)"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    42
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    43
srch_fin_ioa_def "srch_fin_ioa == rename ch_fin_ioa  srch_actions"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    44
rsch_fin_ioa_def "rsch_fin_ioa == rename ch_fin_ioa  rsch_actions"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    45
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    46
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    47
ch_fin_asig_def "ch_fin_asig == ch_asig"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    48
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    49
ch_fin_trans_def "ch_fin_trans ==                                       \
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    50
\ {tr. let s = fst(tr);                                         \
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    51
\          t = snd(snd(tr))                                     \
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    52
\      in                                                       \
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    53
\      case fst(snd(tr))                                        \
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    54
\        of S(b) => ((t = s) |                                    \
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    55
\                   (if (b=hd(reverse(s)) & s~=[]) then  t=s else  t=s@[b])) |    \
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    56
\           R(b) => s ~= [] &                                   \
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    57
\	            b = hd(s) &                                 \
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    58
\	            ((t = s) | (t = tl(s)))    }"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    59
  
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    60
ch_fin_ioa_def "ch_fin_ioa == (ch_fin_asig, {[]}, ch_fin_trans)"
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    61
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    62
end  
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    63
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    64
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    65
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    66
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    67
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    68
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    69
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    70
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    71
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    72
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    73
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    74
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    75
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    76
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    77
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    78
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    79
0c36c6a52a1d ABP: Alternating bit protocol example
nipkow
parents:
diff changeset
    80