MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  fvmptt Structured version   Unicode version

Theorem fvmptt 5972
Description: Closed theorem form of fvmpt 5956. (Contributed by Scott Fenton, 21-Feb-2013.) (Revised by Mario Carneiro, 11-Sep-2015.)
Assertion
Ref Expression
fvmptt  |-  ( ( A. x ( x  =  A  ->  B  =  C )  /\  F  =  ( x  e.  D  |->  B )  /\  ( A  e.  D  /\  C  e.  V
) )  ->  ( F `  A )  =  C )
Distinct variable groups:    x, A    x, C    x, D
Allowed substitution hints:    B( x)    F( x)    V( x)

Proof of Theorem fvmptt
StepHypRef Expression
1 simp2 997 . . 3  |-  ( ( A. x ( x  =  A  ->  B  =  C )  /\  F  =  ( x  e.  D  |->  B )  /\  ( A  e.  D  /\  C  e.  V
) )  ->  F  =  ( x  e.  D  |->  B ) )
21fveq1d 5874 . 2  |-  ( ( A. x ( x  =  A  ->  B  =  C )  /\  F  =  ( x  e.  D  |->  B )  /\  ( A  e.  D  /\  C  e.  V
) )  ->  ( F `  A )  =  ( ( x  e.  D  |->  B ) `
 A ) )
3 risset 2982 . . . . 5  |-  ( A  e.  D  <->  E. x  e.  D  x  =  A )
4 elex 3118 . . . . . 6  |-  ( C  e.  V  ->  C  e.  _V )
5 nfa1 1898 . . . . . . 7  |-  F/ x A. x ( x  =  A  ->  B  =  C )
6 nfv 1708 . . . . . . . 8  |-  F/ x  C  e.  _V
7 nffvmpt1 5880 . . . . . . . . 9  |-  F/_ x
( ( x  e.  D  |->  B ) `  A )
87nfeq1 2634 . . . . . . . 8  |-  F/ x
( ( x  e.  D  |->  B ) `  A )  =  C
96, 8nfim 1921 . . . . . . 7  |-  F/ x
( C  e.  _V  ->  ( ( x  e.  D  |->  B ) `  A )  =  C )
10 simprl 756 . . . . . . . . . . . . 13  |-  ( ( ( x  =  A  /\  B  =  C )  /\  ( x  e.  D  /\  C  e.  _V ) )  ->  x  e.  D )
11 simplr 755 . . . . . . . . . . . . . 14  |-  ( ( ( x  =  A  /\  B  =  C )  /\  ( x  e.  D  /\  C  e.  _V ) )  ->  B  =  C )
12 simprr 757 . . . . . . . . . . . . . 14  |-  ( ( ( x  =  A  /\  B  =  C )  /\  ( x  e.  D  /\  C  e.  _V ) )  ->  C  e.  _V )
1311, 12eqeltrd 2545 . . . . . . . . . . . . 13  |-  ( ( ( x  =  A  /\  B  =  C )  /\  ( x  e.  D  /\  C  e.  _V ) )  ->  B  e.  _V )
14 eqid 2457 . . . . . . . . . . . . . 14  |-  ( x  e.  D  |->  B )  =  ( x  e.  D  |->  B )
1514fvmpt2 5964 . . . . . . . . . . . . 13  |-  ( ( x  e.  D  /\  B  e.  _V )  ->  ( ( x  e.  D  |->  B ) `  x )  =  B )
1610, 13, 15syl2anc 661 . . . . . . . . . . . 12  |-  ( ( ( x  =  A  /\  B  =  C )  /\  ( x  e.  D  /\  C  e.  _V ) )  -> 
( ( x  e.  D  |->  B ) `  x )  =  B )
17 simpll 753 . . . . . . . . . . . . 13  |-  ( ( ( x  =  A  /\  B  =  C )  /\  ( x  e.  D  /\  C  e.  _V ) )  ->  x  =  A )
1817fveq2d 5876 . . . . . . . . . . . 12  |-  ( ( ( x  =  A  /\  B  =  C )  /\  ( x  e.  D  /\  C  e.  _V ) )  -> 
( ( x  e.  D  |->  B ) `  x )  =  ( ( x  e.  D  |->  B ) `  A
) )
1916, 18, 113eqtr3d 2506 . . . . . . . . . . 11  |-  ( ( ( x  =  A  /\  B  =  C )  /\  ( x  e.  D  /\  C  e.  _V ) )  -> 
( ( x  e.  D  |->  B ) `  A )  =  C )
2019exp43 612 . . . . . . . . . 10  |-  ( x  =  A  ->  ( B  =  C  ->  ( x  e.  D  -> 
( C  e.  _V  ->  ( ( x  e.  D  |->  B ) `  A )  =  C ) ) ) )
2120a2i 13 . . . . . . . . 9  |-  ( ( x  =  A  ->  B  =  C )  ->  ( x  =  A  ->  ( x  e.  D  ->  ( C  e.  _V  ->  ( (
x  e.  D  |->  B ) `  A )  =  C ) ) ) )
2221com23 78 . . . . . . . 8  |-  ( ( x  =  A  ->  B  =  C )  ->  ( x  e.  D  ->  ( x  =  A  ->  ( C  e. 
_V  ->  ( ( x  e.  D  |->  B ) `
 A )  =  C ) ) ) )
2322sps 1866 . . . . . . 7  |-  ( A. x ( x  =  A  ->  B  =  C )  ->  (
x  e.  D  -> 
( x  =  A  ->  ( C  e. 
_V  ->  ( ( x  e.  D  |->  B ) `
 A )  =  C ) ) ) )
245, 9, 23rexlimd 2941 . . . . . 6  |-  ( A. x ( x  =  A  ->  B  =  C )  ->  ( E. x  e.  D  x  =  A  ->  ( C  e.  _V  ->  ( ( x  e.  D  |->  B ) `  A
)  =  C ) ) )
254, 24syl7 68 . . . . 5  |-  ( A. x ( x  =  A  ->  B  =  C )  ->  ( E. x  e.  D  x  =  A  ->  ( C  e.  V  -> 
( ( x  e.  D  |->  B ) `  A )  =  C ) ) )
263, 25syl5bi 217 . . . 4  |-  ( A. x ( x  =  A  ->  B  =  C )  ->  ( A  e.  D  ->  ( C  e.  V  -> 
( ( x  e.  D  |->  B ) `  A )  =  C ) ) )
2726imp32 433 . . 3  |-  ( ( A. x ( x  =  A  ->  B  =  C )  /\  ( A  e.  D  /\  C  e.  V )
)  ->  ( (
x  e.  D  |->  B ) `  A )  =  C )
28273adant2 1015 . 2  |-  ( ( A. x ( x  =  A  ->  B  =  C )  /\  F  =  ( x  e.  D  |->  B )  /\  ( A  e.  D  /\  C  e.  V
) )  ->  (
( x  e.  D  |->  B ) `  A
)  =  C )
292, 28eqtrd 2498 1  |-  ( ( A. x ( x  =  A  ->  B  =  C )  /\  F  =  ( x  e.  D  |->  B )  /\  ( A  e.  D  /\  C  e.  V
) )  ->  ( F `  A )  =  C )
Colors of variables: wff setvar class
Syntax hints:    -> wi 4    /\ wa 369    /\ w3a 973   A.wal 1393    = wceq 1395    e. wcel 1819   E.wrex 2808   _Vcvv 3109    |-> cmpt 4515   ` cfv 5594
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1619  ax-4 1632  ax-5 1705  ax-6 1748  ax-7 1791  ax-8 1821  ax-9 1823  ax-10 1838  ax-11 1843  ax-12 1855  ax-13 2000  ax-ext 2435  ax-sep 4578  ax-nul 4586  ax-pow 4634  ax-pr 4695
This theorem depends on definitions:  df-bi 185  df-or 370  df-an 371  df-3an 975  df-tru 1398  df-ex 1614  df-nf 1618  df-sb 1741  df-eu 2287  df-mo 2288  df-clab 2443  df-cleq 2449  df-clel 2452  df-nfc 2607  df-ne 2654  df-ral 2812  df-rex 2813  df-rab 2816  df-v 3111  df-sbc 3328  df-csb 3431  df-dif 3474  df-un 3476  df-in 3478  df-ss 3485  df-nul 3794  df-if 3945  df-sn 4033  df-pr 4035  df-op 4039  df-uni 4252  df-br 4457  df-opab 4516  df-mpt 4517  df-id 4804  df-xp 5014  df-rel 5015  df-cnv 5016  df-co 5017  df-dm 5018  df-rn 5019  df-res 5020  df-ima 5021  df-iota 5557  df-fun 5596  df-fv 5602
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator