Nuprl Lemma : C_TYPEco-ext

C_TYPEco() ≡ lbl:Atom × if lbl =a "Void" then Unit
                        if lbl =a "Int" then Unit
                        if lbl =a "Struct" then (Atom × C_TYPEco()) List
                        if lbl =a "Array" then length:ℕ × C_TYPEco()
                        if lbl =a "Pointer" then C_TYPEco()
                        else Void
                        fi 


Proof




Definitions occuring in Statement :  C_TYPEco: C_TYPEco() list: List nat: ifthenelse: if then else fi  eq_atom: =a y ext-eq: A ≡ B unit: Unit product: x:A × B[x] token: "$token" atom: Atom void: Void
Definitions unfolded in proof :  C_TYPEco: C_TYPEco() uall: [x:A]. B[x] so_lambda: λ2x.t[x] member: t ∈ T so_apply: x[s] uimplies: supposing a continuous-monotone: ContinuousMonotone(T.F[T]) and: P ∧ Q type-monotone: Monotone(T.F[T]) subtype_rel: A ⊆B all: x:A. B[x] implies:  Q bool: 𝔹 unit: Unit it: btrue: tt uiff: uiff(P;Q) ifthenelse: if then else fi  bfalse: ff exists: x:A. B[x] prop: or: P ∨ Q sq_type: SQType(T) guard: {T} bnot: ¬bb assert: b false: False so_lambda: λ2y.t[x; y] so_apply: x[s1;s2] strong-type-continuous: Continuous+(T.F[T]) type-continuous: Continuous(T.F[T])
Lemmas referenced :  corec-ext ifthenelse_wf eq_atom_wf unit_wf2 list_wf nat_wf subtype_rel_product bool_wf eqtt_to_assert assert_of_eq_atom subtype_rel_self eqff_to_assert equal_wf bool_cases_sqequal subtype_base_sq bool_subtype_base assert-bnot neg_assert_of_eq_atom subtype_rel_list subtype_rel_wf strong-continuous-depproduct continuous-constant strong-continuous-list strong-continuous-product continuous-id subtype_rel_weakening
Rules used in proof :  sqequalSubstitution sqequalTransitivity computationStep sqequalReflexivity cut lemma_by_obid sqequalHypSubstitution isectElimination thin sqequalRule lambdaEquality productEquality atomEquality instantiate hypothesisEquality tokenEquality hypothesis universeEquality voidEquality independent_isectElimination independent_pairFormation isect_memberFormation introduction because_Cache lambdaFormation unionElimination equalityElimination productElimination dependent_pairFormation equalityTransitivity equalitySymmetry promote_hyp dependent_functionElimination independent_functionElimination voidElimination equalityEquality axiomEquality isect_memberEquality cumulativity isectEquality applyEquality functionEquality

Latex:
C\_TYPEco()  \mequiv{}  lbl:Atom  \mtimes{}  if  lbl  =a  "Void"  then  Unit
                                                if  lbl  =a  "Int"  then  Unit
                                                if  lbl  =a  "Struct"  then  (Atom  \mtimes{}  C\_TYPEco())  List
                                                if  lbl  =a  "Array"  then  length:\mBbbN{}  \mtimes{}  C\_TYPEco()
                                                if  lbl  =a  "Pointer"  then  C\_TYPEco()
                                                else  Void
                                                fi 



Date html generated: 2016_05_16-AM-08_44_18
Last ObjectModification: 2015_12_28-PM-06_58_39

Theory : C-semantics


Home Index