src/HOLCF/IOA/ABP/Abschannel_finite.thy
author wenzelm
Sat, 03 Sep 2005 16:50:22 +0200
changeset 17244 0b2ff9541727
parent 14981 e73f8140af78
child 19738 1ac610922636
permissions -rw-r--r--
converted to Isar theory format;

(*  Title:      HOLCF/IOA/ABP/Abschannels.thy
    ID:         $Id$
    Author:     Olaf Müller
*)

header {* The transmission channel -- finite version *}

theory Abschannel_finite
imports Abschannel IOA Action Lemmas
begin

consts

ch_fin_asig  :: "'a abs_action signature"

ch_fin_trans :: "('a abs_action, 'a list)transition set"

ch_fin_ioa   :: "('a abs_action, 'a list)ioa"

srch_fin_asig  :: "'m action signature"
rsch_fin_asig  :: "'m action signature"

srch_fin_trans :: "('m action, 'm packet list)transition set"
rsch_fin_trans :: "('m action, bool list)transition set"

srch_fin_ioa   :: "('m action, 'm packet list)ioa"
rsch_fin_ioa   :: "('m action, bool list)ioa"

reverse        :: "'a list => 'a list"

primrec
  reverse_Nil:  "reverse([]) = []"
  reverse_Cons: "reverse(x#xs) =  reverse(xs)@[x]"

defs

srch_fin_asig_def: "srch_fin_asig == asig_of(srch_fin_ioa)"
rsch_fin_asig_def: "rsch_fin_asig == asig_of(rsch_fin_ioa)"

srch_fin_trans_def: "srch_fin_trans == trans_of(srch_fin_ioa)"
rsch_fin_trans_def: "rsch_fin_trans == trans_of(rsch_fin_ioa)"

srch_fin_ioa_def: "srch_fin_ioa == rename ch_fin_ioa  srch_actions"
rsch_fin_ioa_def: "rsch_fin_ioa == rename ch_fin_ioa  rsch_actions"


ch_fin_asig_def: "ch_fin_asig == ch_asig"

ch_fin_trans_def: "ch_fin_trans ==
 {tr. let s = fst(tr);
          t = snd(snd(tr))
      in
      case fst(snd(tr))
        of S(b) => ((t = s) |
                   (if (b=hd(reverse(s)) & s~=[]) then  t=s else  t=s@[b])) |
           R(b) => s ~= [] &
                    b = hd(s) &
                    ((t = s) | (t = tl(s)))    }"

ch_fin_ioa_def: "ch_fin_ioa == (ch_fin_asig, {[]}, ch_fin_trans,{},{})"

ML {* use_legacy_bindings (the_context ()) *}

end