{ [A:Type]. [B:A  Type]. [eq:EqDecider(A)]. [f,g:a:A fp-B[a]].
  [R:a:A. (B[a]  B[a]  )].
    (fpf-compatible-mod(A;a.B[a];eq;
     R;f;g)  ) }

{ Proof }



Definitions occuring in Statement :  fpf-compatible-mod: fpf-compatible-mod fpf: a:A fp-B[a] bool: uall: [x:A]. B[x] prop: so_apply: x[s] member: t  T isect: x:A. B[x] function: x:A  B[x] universe: Type deq: EqDecider(T)
Definitions :  uall: [x:A]. B[x] so_apply: x[s] member: t  T prop: fpf-compatible-mod: fpf-compatible-mod all: x:A. B[x] implies: P  Q and: P  Q so_lambda: x.t[x] uimplies: b supposing a
Lemmas :  assert_wf fpf-dom_wf fpf-trivial-subtype-top not_wf bool_wf fpf-ap_wf fpf_wf deq_wf

\mforall{}[A:Type].  \mforall{}[B:A  {}\mrightarrow{}  Type].  \mforall{}[eq:EqDecider(A)].  \mforall{}[f,g:a:A  fp->  B[a]].  \mforall{}[R:\mcap{}a:A.  (B[a]  {}\mrightarrow{}  B[a]  {}\mrightarrow{}  \mBbbB{})].
    (fpf-compatible-mod(A;a.B[a];eq;
      R;f;g)  \mmember{}  \mBbbP{})


Date html generated: 2011_08_10-AM-07_58_23
Last ObjectModification: 2011_06_18-AM-08_18_21

Home Index