MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  wfrlem5 Structured version   Visualization version   GIF version

Theorem wfrlem5 7570
Description: Lemma for well-founded recursion. The values of two acceptable functions agree within their domains. (Contributed by Scott Fenton, 21-Apr-2011.) (Revised by Mario Carneiro, 26-Jun-2015.)
Hypotheses
Ref Expression
wfrlem5.1 𝑅 We 𝐴
wfrlem5.2 𝑅 Se 𝐴
wfrlem5.3 𝐵 = {𝑓 ∣ ∃𝑥(𝑓 Fn 𝑥 ∧ (𝑥𝐴 ∧ ∀𝑦𝑥 Pred(𝑅, 𝐴, 𝑦) ⊆ 𝑥) ∧ ∀𝑦𝑥 (𝑓𝑦) = (𝐹‘(𝑓 ↾ Pred(𝑅, 𝐴, 𝑦))))}
Assertion
Ref Expression
wfrlem5 ((𝑔𝐵𝐵) → ((𝑥𝑔𝑢𝑥𝑣) → 𝑢 = 𝑣))
Distinct variable groups:   𝐴,𝑓,𝑔,,𝑥,𝑦   𝑓,𝐹,𝑔,,𝑥,𝑦   𝑅,𝑓,𝑔,,𝑥,𝑦   𝑢,𝑔,𝑣,,𝑥
Allowed substitution hints:   𝐴(𝑣,𝑢)   𝐵(𝑥,𝑦,𝑣,𝑢,𝑓,𝑔,)   𝑅(𝑣,𝑢)   𝐹(𝑣,𝑢)

Proof of Theorem wfrlem5
Dummy variable 𝑎 is distinct from all other variables.
StepHypRef Expression
1 vex 3354 . . . . . 6 𝑥 ∈ V
2 vex 3354 . . . . . 6 𝑢 ∈ V
31, 2breldm 5465 . . . . 5 (𝑥𝑔𝑢𝑥 ∈ dom 𝑔)
4 vex 3354 . . . . . 6 𝑣 ∈ V
51, 4breldm 5465 . . . . 5 (𝑥𝑣𝑥 ∈ dom )
63, 5anim12i 600 . . . 4 ((𝑥𝑔𝑢𝑥𝑣) → (𝑥 ∈ dom 𝑔𝑥 ∈ dom ))
7 elin 3947 . . . 4 (𝑥 ∈ (dom 𝑔 ∩ dom ) ↔ (𝑥 ∈ dom 𝑔𝑥 ∈ dom ))
86, 7sylibr 224 . . 3 ((𝑥𝑔𝑢𝑥𝑣) → 𝑥 ∈ (dom 𝑔 ∩ dom ))
9 anandir 656 . . . 4 (((𝑥𝑔𝑢𝑥𝑣) ∧ 𝑥 ∈ (dom 𝑔 ∩ dom )) ↔ ((𝑥𝑔𝑢𝑥 ∈ (dom 𝑔 ∩ dom )) ∧ (𝑥𝑣𝑥 ∈ (dom 𝑔 ∩ dom ))))
102brres 5541 . . . . 5 (𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢 ↔ (𝑥𝑔𝑢𝑥 ∈ (dom 𝑔 ∩ dom )))
114brres 5541 . . . . 5 (𝑥( ↾ (dom 𝑔 ∩ dom ))𝑣 ↔ (𝑥𝑣𝑥 ∈ (dom 𝑔 ∩ dom )))
1210, 11anbi12i 612 . . . 4 ((𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥( ↾ (dom 𝑔 ∩ dom ))𝑣) ↔ ((𝑥𝑔𝑢𝑥 ∈ (dom 𝑔 ∩ dom )) ∧ (𝑥𝑣𝑥 ∈ (dom 𝑔 ∩ dom ))))
139, 12sylbb2 228 . . 3 (((𝑥𝑔𝑢𝑥𝑣) ∧ 𝑥 ∈ (dom 𝑔 ∩ dom )) → (𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥( ↾ (dom 𝑔 ∩ dom ))𝑣))
148, 13mpdan 667 . 2 ((𝑥𝑔𝑢𝑥𝑣) → (𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥( ↾ (dom 𝑔 ∩ dom ))𝑣))
15 wfrlem5.3 . . . . . . . . 9 𝐵 = {𝑓 ∣ ∃𝑥(𝑓 Fn 𝑥 ∧ (𝑥𝐴 ∧ ∀𝑦𝑥 Pred(𝑅, 𝐴, 𝑦) ⊆ 𝑥) ∧ ∀𝑦𝑥 (𝑓𝑦) = (𝐹‘(𝑓 ↾ Pred(𝑅, 𝐴, 𝑦))))}
1615wfrlem3 7566 . . . . . . . 8 (𝑔𝐵 → dom 𝑔𝐴)
17 ssinss1 3990 . . . . . . . 8 (dom 𝑔𝐴 → (dom 𝑔 ∩ dom ) ⊆ 𝐴)
18 wfrlem5.1 . . . . . . . . . 10 𝑅 We 𝐴
19 wess 5236 . . . . . . . . . 10 ((dom 𝑔 ∩ dom ) ⊆ 𝐴 → (𝑅 We 𝐴𝑅 We (dom 𝑔 ∩ dom )))
2018, 19mpi 20 . . . . . . . . 9 ((dom 𝑔 ∩ dom ) ⊆ 𝐴𝑅 We (dom 𝑔 ∩ dom ))
21 wfrlem5.2 . . . . . . . . . 10 𝑅 Se 𝐴
22 sess2 5218 . . . . . . . . . 10 ((dom 𝑔 ∩ dom ) ⊆ 𝐴 → (𝑅 Se 𝐴𝑅 Se (dom 𝑔 ∩ dom )))
2321, 22mpi 20 . . . . . . . . 9 ((dom 𝑔 ∩ dom ) ⊆ 𝐴𝑅 Se (dom 𝑔 ∩ dom ))
2420, 23jca 501 . . . . . . . 8 ((dom 𝑔 ∩ dom ) ⊆ 𝐴 → (𝑅 We (dom 𝑔 ∩ dom ) ∧ 𝑅 Se (dom 𝑔 ∩ dom )))
2516, 17, 243syl 18 . . . . . . 7 (𝑔𝐵 → (𝑅 We (dom 𝑔 ∩ dom ) ∧ 𝑅 Se (dom 𝑔 ∩ dom )))
2625adantr 466 . . . . . 6 ((𝑔𝐵𝐵) → (𝑅 We (dom 𝑔 ∩ dom ) ∧ 𝑅 Se (dom 𝑔 ∩ dom )))
2715wfrlem4 7568 . . . . . 6 ((𝑔𝐵𝐵) → ((𝑔 ↾ (dom 𝑔 ∩ dom )) Fn (dom 𝑔 ∩ dom ) ∧ ∀𝑎 ∈ (dom 𝑔 ∩ dom )((𝑔 ↾ (dom 𝑔 ∩ dom ))‘𝑎) = (𝐹‘((𝑔 ↾ (dom 𝑔 ∩ dom )) ↾ Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎)))))
2815wfrlem4 7568 . . . . . . . 8 ((𝐵𝑔𝐵) → (( ↾ (dom ∩ dom 𝑔)) Fn (dom ∩ dom 𝑔) ∧ ∀𝑎 ∈ (dom ∩ dom 𝑔)(( ↾ (dom ∩ dom 𝑔))‘𝑎) = (𝐹‘(( ↾ (dom ∩ dom 𝑔)) ↾ Pred(𝑅, (dom ∩ dom 𝑔), 𝑎)))))
2928ancoms 446 . . . . . . 7 ((𝑔𝐵𝐵) → (( ↾ (dom ∩ dom 𝑔)) Fn (dom ∩ dom 𝑔) ∧ ∀𝑎 ∈ (dom ∩ dom 𝑔)(( ↾ (dom ∩ dom 𝑔))‘𝑎) = (𝐹‘(( ↾ (dom ∩ dom 𝑔)) ↾ Pred(𝑅, (dom ∩ dom 𝑔), 𝑎)))))
30 incom 3956 . . . . . . . . . . 11 (dom 𝑔 ∩ dom ) = (dom ∩ dom 𝑔)
3130reseq2i 5529 . . . . . . . . . 10 ( ↾ (dom 𝑔 ∩ dom )) = ( ↾ (dom ∩ dom 𝑔))
3231fneq1i 6123 . . . . . . . . 9 (( ↾ (dom 𝑔 ∩ dom )) Fn (dom 𝑔 ∩ dom ) ↔ ( ↾ (dom ∩ dom 𝑔)) Fn (dom 𝑔 ∩ dom ))
3330fneq2i 6124 . . . . . . . . 9 (( ↾ (dom ∩ dom 𝑔)) Fn (dom 𝑔 ∩ dom ) ↔ ( ↾ (dom ∩ dom 𝑔)) Fn (dom ∩ dom 𝑔))
3432, 33bitri 264 . . . . . . . 8 (( ↾ (dom 𝑔 ∩ dom )) Fn (dom 𝑔 ∩ dom ) ↔ ( ↾ (dom ∩ dom 𝑔)) Fn (dom ∩ dom 𝑔))
3531fveq1i 6331 . . . . . . . . . 10 (( ↾ (dom 𝑔 ∩ dom ))‘𝑎) = (( ↾ (dom ∩ dom 𝑔))‘𝑎)
36 predeq2 5824 . . . . . . . . . . . . 13 ((dom 𝑔 ∩ dom ) = (dom ∩ dom 𝑔) → Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎) = Pred(𝑅, (dom ∩ dom 𝑔), 𝑎))
3730, 36ax-mp 5 . . . . . . . . . . . 12 Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎) = Pred(𝑅, (dom ∩ dom 𝑔), 𝑎)
3831, 37reseq12i 5530 . . . . . . . . . . 11 (( ↾ (dom 𝑔 ∩ dom )) ↾ Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎)) = (( ↾ (dom ∩ dom 𝑔)) ↾ Pred(𝑅, (dom ∩ dom 𝑔), 𝑎))
3938fveq2i 6333 . . . . . . . . . 10 (𝐹‘(( ↾ (dom 𝑔 ∩ dom )) ↾ Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎))) = (𝐹‘(( ↾ (dom ∩ dom 𝑔)) ↾ Pred(𝑅, (dom ∩ dom 𝑔), 𝑎)))
4035, 39eqeq12i 2785 . . . . . . . . 9 ((( ↾ (dom 𝑔 ∩ dom ))‘𝑎) = (𝐹‘(( ↾ (dom 𝑔 ∩ dom )) ↾ Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎))) ↔ (( ↾ (dom ∩ dom 𝑔))‘𝑎) = (𝐹‘(( ↾ (dom ∩ dom 𝑔)) ↾ Pred(𝑅, (dom ∩ dom 𝑔), 𝑎))))
4130, 40raleqbii 3139 . . . . . . . 8 (∀𝑎 ∈ (dom 𝑔 ∩ dom )(( ↾ (dom 𝑔 ∩ dom ))‘𝑎) = (𝐹‘(( ↾ (dom 𝑔 ∩ dom )) ↾ Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎))) ↔ ∀𝑎 ∈ (dom ∩ dom 𝑔)(( ↾ (dom ∩ dom 𝑔))‘𝑎) = (𝐹‘(( ↾ (dom ∩ dom 𝑔)) ↾ Pred(𝑅, (dom ∩ dom 𝑔), 𝑎))))
4234, 41anbi12i 612 . . . . . . 7 ((( ↾ (dom 𝑔 ∩ dom )) Fn (dom 𝑔 ∩ dom ) ∧ ∀𝑎 ∈ (dom 𝑔 ∩ dom )(( ↾ (dom 𝑔 ∩ dom ))‘𝑎) = (𝐹‘(( ↾ (dom 𝑔 ∩ dom )) ↾ Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎)))) ↔ (( ↾ (dom ∩ dom 𝑔)) Fn (dom ∩ dom 𝑔) ∧ ∀𝑎 ∈ (dom ∩ dom 𝑔)(( ↾ (dom ∩ dom 𝑔))‘𝑎) = (𝐹‘(( ↾ (dom ∩ dom 𝑔)) ↾ Pred(𝑅, (dom ∩ dom 𝑔), 𝑎)))))
4329, 42sylibr 224 . . . . . 6 ((𝑔𝐵𝐵) → (( ↾ (dom 𝑔 ∩ dom )) Fn (dom 𝑔 ∩ dom ) ∧ ∀𝑎 ∈ (dom 𝑔 ∩ dom )(( ↾ (dom 𝑔 ∩ dom ))‘𝑎) = (𝐹‘(( ↾ (dom 𝑔 ∩ dom )) ↾ Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎)))))
44 wfr3g 7563 . . . . . 6 (((𝑅 We (dom 𝑔 ∩ dom ) ∧ 𝑅 Se (dom 𝑔 ∩ dom )) ∧ ((𝑔 ↾ (dom 𝑔 ∩ dom )) Fn (dom 𝑔 ∩ dom ) ∧ ∀𝑎 ∈ (dom 𝑔 ∩ dom )((𝑔 ↾ (dom 𝑔 ∩ dom ))‘𝑎) = (𝐹‘((𝑔 ↾ (dom 𝑔 ∩ dom )) ↾ Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎)))) ∧ (( ↾ (dom 𝑔 ∩ dom )) Fn (dom 𝑔 ∩ dom ) ∧ ∀𝑎 ∈ (dom 𝑔 ∩ dom )(( ↾ (dom 𝑔 ∩ dom ))‘𝑎) = (𝐹‘(( ↾ (dom 𝑔 ∩ dom )) ↾ Pred(𝑅, (dom 𝑔 ∩ dom ), 𝑎))))) → (𝑔 ↾ (dom 𝑔 ∩ dom )) = ( ↾ (dom 𝑔 ∩ dom )))
4526, 27, 43, 44syl3anc 1476 . . . . 5 ((𝑔𝐵𝐵) → (𝑔 ↾ (dom 𝑔 ∩ dom )) = ( ↾ (dom 𝑔 ∩ dom )))
4645breqd 4797 . . . 4 ((𝑔𝐵𝐵) → (𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑣𝑥( ↾ (dom 𝑔 ∩ dom ))𝑣))
4746biimprd 238 . . 3 ((𝑔𝐵𝐵) → (𝑥( ↾ (dom 𝑔 ∩ dom ))𝑣𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑣))
4815wfrlem2 7565 . . . . 5 (𝑔𝐵 → Fun 𝑔)
49 funres 6070 . . . . 5 (Fun 𝑔 → Fun (𝑔 ↾ (dom 𝑔 ∩ dom )))
50 dffun2 6039 . . . . . 6 (Fun (𝑔 ↾ (dom 𝑔 ∩ dom )) ↔ (Rel (𝑔 ↾ (dom 𝑔 ∩ dom )) ∧ ∀𝑥𝑢𝑣((𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑣) → 𝑢 = 𝑣)))
5150simprbi 484 . . . . 5 (Fun (𝑔 ↾ (dom 𝑔 ∩ dom )) → ∀𝑥𝑢𝑣((𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑣) → 𝑢 = 𝑣))
52 2sp 2210 . . . . . 6 (∀𝑢𝑣((𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑣) → 𝑢 = 𝑣) → ((𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑣) → 𝑢 = 𝑣))
5352sps 2209 . . . . 5 (∀𝑥𝑢𝑣((𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑣) → 𝑢 = 𝑣) → ((𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑣) → 𝑢 = 𝑣))
5448, 49, 51, 534syl 19 . . . 4 (𝑔𝐵 → ((𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑣) → 𝑢 = 𝑣))
5554adantr 466 . . 3 ((𝑔𝐵𝐵) → ((𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑣) → 𝑢 = 𝑣))
5647, 55sylan2d 592 . 2 ((𝑔𝐵𝐵) → ((𝑥(𝑔 ↾ (dom 𝑔 ∩ dom ))𝑢𝑥( ↾ (dom 𝑔 ∩ dom ))𝑣) → 𝑢 = 𝑣))
5714, 56syl5 34 1 ((𝑔𝐵𝐵) → ((𝑥𝑔𝑢𝑥𝑣) → 𝑢 = 𝑣))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 382  w3a 1071  wal 1629   = wceq 1631  wex 1852  wcel 2145  {cab 2757  wral 3061  cin 3722  wss 3723   class class class wbr 4786   Se wse 5206   We wwe 5207  dom cdm 5249  cres 5251  Rel wrel 5254  Predcpred 5820  Fun wfun 6023   Fn wfn 6024  cfv 6029
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1870  ax-4 1885  ax-5 1991  ax-6 2057  ax-7 2093  ax-8 2147  ax-9 2154  ax-10 2174  ax-11 2190  ax-12 2203  ax-13 2408  ax-ext 2751  ax-sep 4915  ax-nul 4923  ax-pow 4974  ax-pr 5034
This theorem depends on definitions:  df-bi 197  df-an 383  df-or 837  df-3or 1072  df-3an 1073  df-tru 1634  df-ex 1853  df-nf 1858  df-sb 2050  df-eu 2622  df-mo 2623  df-clab 2758  df-cleq 2764  df-clel 2767  df-nfc 2902  df-ne 2944  df-ral 3066  df-rex 3067  df-reu 3068  df-rmo 3069  df-rab 3070  df-v 3353  df-sbc 3588  df-csb 3683  df-dif 3726  df-un 3728  df-in 3730  df-ss 3737  df-nul 4064  df-if 4226  df-sn 4317  df-pr 4319  df-op 4323  df-uni 4575  df-br 4787  df-opab 4847  df-mpt 4864  df-id 5157  df-po 5170  df-so 5171  df-fr 5208  df-se 5209  df-we 5210  df-xp 5255  df-rel 5256  df-cnv 5257  df-co 5258  df-dm 5259  df-rn 5260  df-res 5261  df-ima 5262  df-pred 5821  df-iota 5992  df-fun 6031  df-fn 6032  df-fv 6037
This theorem is referenced by:  wfrfun  7576
  Copyright terms: Public domain W3C validator