Nuprl Lemma : RankEx1-ext

[T:Type]
  RankEx1(T) ≡ lbl:Atom × if lbl =a "Leaf" then T
                          if lbl =a "Prod" then RankEx1(T) × RankEx1(T)
                          if lbl =a "ProdL" then T × RankEx1(T)
                          if lbl =a "ProdR" then RankEx1(T) × T
                          if lbl =a "List" then RankEx1(T) List
                          else Void
                          fi 


Proof




Definitions occuring in Statement :  RankEx1: RankEx1(T) list: List ifthenelse: if then else fi  eq_atom: =a y ext-eq: A ≡ B uall: [x:A]. B[x] product: x:A × B[x] token: "$token" atom: Atom void: Void universe: Type
Definitions unfolded in proof :  uall: [x:A]. B[x] ext-eq: A ≡ B and: P ∧ Q subtype_rel: A ⊆B member: t ∈ T RankEx1: RankEx1(T) all: x:A. B[x] implies:  Q bool: 𝔹 unit: Unit it: btrue: tt uiff: uiff(P;Q) uimplies: supposing a ifthenelse: if then else fi  sq_type: SQType(T) guard: {T} eq_atom: =a y bfalse: ff exists: x:A. B[x] prop: or: P ∨ Q bnot: ¬bb assert: b false: False RankEx1co_size: RankEx1co_size(p) pi1: fst(t) pi2: snd(t) nat: so_lambda: λ2x.t[x] so_apply: x[s] has-value: (a)↓ l_all: (∀x∈L.P[x]) int_seg: {i..j-} nequal: a ≠ b ∈  lelt: i ≤ j < k decidable: Dec(P) satisfiable_int_formula: satisfiable_int_formula(fmla) not: ¬A top: Top less_than: a < b squash: T RankEx1_size: RankEx1_size(p) le: A ≤ B less_than': less_than'(a;b)
Lemmas referenced :  sum-nat nat_properties RankEx1_size_wf false_wf add-nat subtype_rel_list list_wf RankEx1_wf ifthenelse_wf sum-partial-nat int_seg_wf int_formula_prop_less_lemma intformless_wf decidable__lt int_formula_prop_wf int_term_value_var_lemma int_term_value_constant_lemma int_formula_prop_le_lemma int_formula_prop_not_lemma int_formula_prop_and_lemma itermVar_wf itermConstant_wf intformle_wf intformnot_wf intformand_wf satisfiable-full-omega-tt decidable__le length_wf int_seg_properties select_wf length_wf_nat sum-partial-has-value RankEx1co_wf list-set-type2 set-value-type has-value_wf-partial int-value-type value-type-has-value base_wf le_wf set_subtype_base nat_wf subtype_partial_sqtype_base RankEx1co_size_wf int_subtype_base neg_assert_of_eq_atom assert-bnot bool_subtype_base bool_cases_sqequal equal_wf eqff_to_assert atom_subtype_base subtype_base_sq assert_of_eq_atom eqtt_to_assert bool_wf eq_atom_wf RankEx1co-ext
Rules used in proof :  sqequalSubstitution sqequalTransitivity computationStep sqequalReflexivity isect_memberFormation independent_pairFormation lambdaEquality sqequalHypSubstitution setElimination thin rename cut lemma_by_obid hypothesis isectElimination hypothesisEquality promote_hyp productElimination hypothesis_subsumption applyEquality sqequalRule dependent_pairEquality tokenEquality lambdaFormation unionElimination equalityElimination equalityTransitivity equalitySymmetry independent_isectElimination because_Cache instantiate cumulativity atomEquality dependent_functionElimination independent_functionElimination dependent_pairFormation voidElimination independent_pairEquality dependent_set_memberEquality natural_numberEquality intEquality baseApply closedConclusion baseClosed equalityEquality callbyvalueAdd int_eqEquality isect_memberEquality voidEquality computeAll imageElimination universeEquality productEquality sqleReflexivity

Latex:
\mforall{}[T:Type]
    RankEx1(T)  \mequiv{}  lbl:Atom  \mtimes{}  if  lbl  =a  "Leaf"  then  T
                                                    if  lbl  =a  "Prod"  then  RankEx1(T)  \mtimes{}  RankEx1(T)
                                                    if  lbl  =a  "ProdL"  then  T  \mtimes{}  RankEx1(T)
                                                    if  lbl  =a  "ProdR"  then  RankEx1(T)  \mtimes{}  T
                                                    if  lbl  =a  "List"  then  RankEx1(T)  List
                                                    else  Void
                                                    fi 



Date html generated: 2016_05_16-AM-08_56_30
Last ObjectModification: 2016_01_17-AM-09_41_35

Theory : C-semantics


Home Index