{  [A:Type]. 
[A:Type].  [B:A 
[B:A 
  Type]. 
 Type].  [f:a:A fp-> B[a]]. 
[f:a:A fp-> B[a]].  [eq:EqDecider(A)]. 
[eq:EqDecider(A)].  [x:A].
[x:A].
   [P:a:{a:A| 
[P:a:{a:A|  a 
a   dom(f)}  
 dom(f)}  
  B[a] 
 B[a] 
  
  ].
].
    (z != f(x) ==> P[x;z]   
  ) }
) }
{ Proof }
Definitions occuring in Statement : 
fpf-val: z != f(x) ==> P[a; z], 
fpf-dom: x   dom(f), 
fpf: a:A fp-> B[a], 
assert:
 dom(f), 
fpf: a:A fp-> B[a], 
assert:  b, 
uall:
b, 
uall:  [x:A]. B[x], 
prop:
[x:A]. B[x], 
prop:  , 
so_apply: x[s1;s2], 
so_apply: x[s], 
member: t 
, 
so_apply: x[s1;s2], 
so_apply: x[s], 
member: t   T, 
set: {x:A| B[x]} , 
function: x:A 
 T, 
set: {x:A| B[x]} , 
function: x:A 
  B[x], 
universe: Type, 
deq: EqDecider(T)
 B[x], 
universe: Type, 
deq: EqDecider(T)
Definitions : 
uall:  [x:A]. B[x], 
so_apply: x[s], 
prop:
[x:A]. B[x], 
so_apply: x[s], 
prop:  , 
member: t 
, 
member: t   T, 
fpf-val: z != f(x) ==> P[a; z], 
so_apply: x[s1;s2], 
implies: P 
 T, 
fpf-val: z != f(x) ==> P[a; z], 
so_apply: x[s1;s2], 
implies: P 
  Q, 
so_lambda:
 Q, 
so_lambda: 
 x.t[x], 
uimplies: b supposing a
x.t[x], 
uimplies: b supposing a
Lemmas : 
assert_wf, 
fpf-dom_wf, 
fpf-trivial-subtype-top, 
fpf-ap_wf, 
deq_wf, 
fpf_wf
\mforall{}[A:Type].  \mforall{}[B:A  {}\mrightarrow{}  Type].  \mforall{}[f:a:A  fp->  B[a]].  \mforall{}[eq:EqDecider(A)].  \mforall{}[x:A].  \mforall{}[P:a:\{a:A|  \muparrow{}a  \mmember{}  dom(f)\}  
                                                                                                                                                              {}\mrightarrow{}  B[a]
                                                                                                                                                              {}\mrightarrow{}  \mBbbP{}].
    (z  !=  f(x)  ==>  P[x;z]  \mmember{}  \mBbbP{})
 Date html generated: 
2011_08_10-AM-07_56_37
 Last ObjectModification: 
2011_06_18-AM-08_17_18
Home
Index