ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  riota5f Unicode version

Theorem riota5f 5833
Description: A method for computing restricted iota. (Contributed by NM, 16-Apr-2013.) (Revised by Mario Carneiro, 15-Oct-2016.)
Hypotheses
Ref Expression
riota5f.1  |-  ( ph  -> 
F/_ x B )
riota5f.2  |-  ( ph  ->  B  e.  A )
riota5f.3  |-  ( (
ph  /\  x  e.  A )  ->  ( ps 
<->  x  =  B ) )
Assertion
Ref Expression
riota5f  |-  ( ph  ->  ( iota_ x  e.  A  ps )  =  B
)
Distinct variable groups:    x, A    ph, x
Allowed substitution hints:    ps( x)    B( x)

Proof of Theorem riota5f
Dummy variable  y is distinct from all other variables.
StepHypRef Expression
1 riota5f.3 . . 3  |-  ( (
ph  /\  x  e.  A )  ->  ( ps 
<->  x  =  B ) )
21ralrimiva 2543 . 2  |-  ( ph  ->  A. x  e.  A  ( ps  <->  x  =  B
) )
3 riota5f.2 . . . 4  |-  ( ph  ->  B  e.  A )
4 a1tru 1364 . . . . . . 7  |-  ( (
ph  /\  ( y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y ) ) )  -> T.  )
5 reu6i 2921 . . . . . . . . 9  |-  ( ( y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) )  ->  E! x  e.  A  ps )
65adantl 275 . . . . . . . 8  |-  ( (
ph  /\  ( y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y ) ) )  ->  E! x  e.  A  ps )
7 nfv 1521 . . . . . . . . . 10  |-  F/ x ph
8 nfv 1521 . . . . . . . . . . 11  |-  F/ x  y  e.  A
9 nfra1 2501 . . . . . . . . . . 11  |-  F/ x A. x  e.  A  ( ps  <->  x  =  y
)
108, 9nfan 1558 . . . . . . . . . 10  |-  F/ x
( y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) )
117, 10nfan 1558 . . . . . . . . 9  |-  F/ x
( ph  /\  (
y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) ) )
12 nfcvd 2313 . . . . . . . . 9  |-  ( (
ph  /\  ( y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y ) ) )  ->  F/_ x y )
13 nfvd 1522 . . . . . . . . 9  |-  ( (
ph  /\  ( y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y ) ) )  ->  F/ x T.  )
14 simprl 526 . . . . . . . . 9  |-  ( (
ph  /\  ( y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y ) ) )  ->  y  e.  A )
15 simpr 109 . . . . . . . . . . 11  |-  ( ( ( ph  /\  (
y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) ) )  /\  x  =  y )  ->  x  =  y )
16 simplrr 531 . . . . . . . . . . . 12  |-  ( ( ( ph  /\  (
y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) ) )  /\  x  =  y )  ->  A. x  e.  A  ( ps  <->  x  =  y
) )
17 simplrl 530 . . . . . . . . . . . . 13  |-  ( ( ( ph  /\  (
y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) ) )  /\  x  =  y )  ->  y  e.  A )
1815, 17eqeltrd 2247 . . . . . . . . . . . 12  |-  ( ( ( ph  /\  (
y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) ) )  /\  x  =  y )  ->  x  e.  A )
19 rsp 2517 . . . . . . . . . . . 12  |-  ( A. x  e.  A  ( ps 
<->  x  =  y )  ->  ( x  e.  A  ->  ( ps  <->  x  =  y ) ) )
2016, 18, 19sylc 62 . . . . . . . . . . 11  |-  ( ( ( ph  /\  (
y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) ) )  /\  x  =  y )  ->  ( ps  <->  x  =  y ) )
2115, 20mpbird 166 . . . . . . . . . 10  |-  ( ( ( ph  /\  (
y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) ) )  /\  x  =  y )  ->  ps )
22 a1tru 1364 . . . . . . . . . 10  |-  ( ( ( ph  /\  (
y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) ) )  /\  x  =  y )  -> T.  )
2321, 222thd 174 . . . . . . . . 9  |-  ( ( ( ph  /\  (
y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) ) )  /\  x  =  y )  ->  ( ps  <-> T.  )
)
2411, 12, 13, 14, 23riota2df 5829 . . . . . . . 8  |-  ( ( ( ph  /\  (
y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y
) ) )  /\  E! x  e.  A  ps )  ->  ( T.  <-> 
( iota_ x  e.  A  ps )  =  y
) )
256, 24mpdan 419 . . . . . . 7  |-  ( (
ph  /\  ( y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y ) ) )  ->  ( T.  <->  (
iota_ x  e.  A  ps )  =  y
) )
264, 25mpbid 146 . . . . . 6  |-  ( (
ph  /\  ( y  e.  A  /\  A. x  e.  A  ( ps  <->  x  =  y ) ) )  ->  ( iota_ x  e.  A  ps )  =  y )
2726expr 373 . . . . 5  |-  ( (
ph  /\  y  e.  A )  ->  ( A. x  e.  A  ( ps  <->  x  =  y
)  ->  ( iota_ x  e.  A  ps )  =  y ) )
2827ralrimiva 2543 . . . 4  |-  ( ph  ->  A. y  e.  A  ( A. x  e.  A  ( ps  <->  x  =  y
)  ->  ( iota_ x  e.  A  ps )  =  y ) )
29 rspsbc 3037 . . . 4  |-  ( B  e.  A  ->  ( A. y  e.  A  ( A. x  e.  A  ( ps  <->  x  =  y
)  ->  ( iota_ x  e.  A  ps )  =  y )  ->  [. B  /  y ]. ( A. x  e.  A  ( ps  <->  x  =  y )  ->  ( iota_ x  e.  A  ps )  =  y )
) )
303, 28, 29sylc 62 . . 3  |-  ( ph  ->  [. B  /  y ]. ( A. x  e.  A  ( ps  <->  x  =  y )  ->  ( iota_ x  e.  A  ps )  =  y )
)
31 nfcvd 2313 . . . . . . . 8  |-  ( ph  -> 
F/_ x y )
32 riota5f.1 . . . . . . . 8  |-  ( ph  -> 
F/_ x B )
3331, 32nfeqd 2327 . . . . . . 7  |-  ( ph  ->  F/ x  y  =  B )
347, 33nfan1 1557 . . . . . 6  |-  F/ x
( ph  /\  y  =  B )
35 simpr 109 . . . . . . . 8  |-  ( (
ph  /\  y  =  B )  ->  y  =  B )
3635eqeq2d 2182 . . . . . . 7  |-  ( (
ph  /\  y  =  B )  ->  (
x  =  y  <->  x  =  B ) )
3736bibi2d 231 . . . . . 6  |-  ( (
ph  /\  y  =  B )  ->  (
( ps  <->  x  =  y )  <->  ( ps  <->  x  =  B ) ) )
3834, 37ralbid 2468 . . . . 5  |-  ( (
ph  /\  y  =  B )  ->  ( A. x  e.  A  ( ps  <->  x  =  y
)  <->  A. x  e.  A  ( ps  <->  x  =  B
) ) )
3935eqeq2d 2182 . . . . 5  |-  ( (
ph  /\  y  =  B )  ->  (
( iota_ x  e.  A  ps )  =  y  <->  (
iota_ x  e.  A  ps )  =  B
) )
4038, 39imbi12d 233 . . . 4  |-  ( (
ph  /\  y  =  B )  ->  (
( A. x  e.  A  ( ps  <->  x  =  y )  ->  ( iota_ x  e.  A  ps )  =  y )  <->  ( A. x  e.  A  ( ps  <->  x  =  B
)  ->  ( iota_ x  e.  A  ps )  =  B ) ) )
413, 40sbcied 2991 . . 3  |-  ( ph  ->  ( [. B  / 
y ]. ( A. x  e.  A  ( ps  <->  x  =  y )  -> 
( iota_ x  e.  A  ps )  =  y
)  <->  ( A. x  e.  A  ( ps  <->  x  =  B )  -> 
( iota_ x  e.  A  ps )  =  B
) ) )
4230, 41mpbid 146 . 2  |-  ( ph  ->  ( A. x  e.  A  ( ps  <->  x  =  B )  ->  ( iota_ x  e.  A  ps )  =  B )
)
432, 42mpd 13 1  |-  ( ph  ->  ( iota_ x  e.  A  ps )  =  B
)
Colors of variables: wff set class
Syntax hints:    -> wi 4    /\ wa 103    <-> wb 104    = wceq 1348   T. wtru 1349    e. wcel 2141   F/_wnfc 2299   A.wral 2448   E!wreu 2450   [.wsbc 2955   iota_crio 5808
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 105  ax-ia2 106  ax-ia3 107  ax-io 704  ax-5 1440  ax-7 1441  ax-gen 1442  ax-ie1 1486  ax-ie2 1487  ax-8 1497  ax-10 1498  ax-11 1499  ax-i12 1500  ax-bndl 1502  ax-4 1503  ax-17 1519  ax-i9 1523  ax-ial 1527  ax-i5r 1528  ax-ext 2152
This theorem depends on definitions:  df-bi 116  df-3an 975  df-tru 1351  df-nf 1454  df-sb 1756  df-eu 2022  df-clab 2157  df-cleq 2163  df-clel 2166  df-nfc 2301  df-ral 2453  df-rex 2454  df-reu 2455  df-v 2732  df-sbc 2956  df-un 3125  df-sn 3589  df-pr 3590  df-uni 3797  df-iota 5160  df-riota 5809
This theorem is referenced by:  riota5  5834
  Copyright terms: Public domain W3C validator