src/ZF/Coind/ECR.thy
author lcp
Tue, 25 Apr 1995 11:14:03 +0200
changeset 1072 0140ff702b23
parent 930 63f02d32509e
child 1155 928a16e02f9f
permissions -rw-r--r--
updated version

(*  Title: 	ZF/Coind/ECR.thy
    ID:         $Id$
    Author: 	Jacob Frost, Cambridge University Computer Laboratory
    Copyright   1995  University of Cambridge
*)

ECR = Static + Dynamic +

(* The extended correspondence relation *)

consts
  HasTyRel :: "i"
coinductive
  domains "HasTyRel" <= "Val * Ty"
  intrs
    htr_constI
      "[| c:Const; t:Ty; isof(c,t) |] ==> <v_const(c),t>:HasTyRel"
    htr_closI
      "[| x:ExVar; e:Exp; t:Ty; ve:ValEnv; te:TyEnv; \
\	  <te,e_fn(x,e),t>:ElabRel;  \
\	  ve_dom(ve) = te_dom(te);   \
\	  {<ve_app(ve,y),te_app(te,y)>.y:ve_dom(ve)}:Pow(HasTyRel)  \
\      |] ==>   \
\      <v_clos(x,e,ve),t>:HasTyRel" 
  monos "[Pow_mono]"
  type_intrs "Val_ValEnv.intrs"
  
(* Pointwise extension to environments *)
 
consts
  hastyenv :: "[i,i] => o"
defs
  hastyenv_def 
    " hastyenv(ve,te) == 			\
\     ve_dom(ve) = te_dom(te) & 		\
\     (ALL x:ve_dom(ve). <ve_app(ve,x),te_app(te,x)>:HasTyRel)"

end