Users' Mathboxes Mathbox for Thierry Arnoux < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  ofpreima2 Structured version   Visualization version   GIF version

Theorem ofpreima2 32865
Description: Express the preimage of a function operation as a union of preimages. This version of ofpreima 32864 iterates the union over a smaller set. (Contributed by Thierry Arnoux, 8-Mar-2018.)
Hypotheses
Ref Expression
ofpreima.1 (𝜑𝐹:𝐴𝐵)
ofpreima.2 (𝜑𝐺:𝐴𝐶)
ofpreima.3 (𝜑𝐴𝑉)
ofpreima.4 (𝜑𝑅 Fn (𝐵 × 𝐶))
Assertion
Ref Expression
ofpreima2 (𝜑 → ((𝐹f 𝑅𝐺) “ 𝐷) = 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})))
Distinct variable groups:   𝐴,𝑝   𝐷,𝑝   𝐹,𝑝   𝐺,𝑝   𝑅,𝑝   𝜑,𝑝
Allowed substitution hints:   𝐵(𝑝)   𝐶(𝑝)   𝑉(𝑝)

Proof of Theorem ofpreima2
StepHypRef Expression
1 ofpreima.1 . . . 4 (𝜑𝐹:𝐴𝐵)
2 ofpreima.2 . . . 4 (𝜑𝐺:𝐴𝐶)
3 ofpreima.3 . . . 4 (𝜑𝐴𝑉)
4 ofpreima.4 . . . 4 (𝜑𝑅 Fn (𝐵 × 𝐶))
51, 2, 3, 4ofpreima 32864 . . 3 (𝜑 → ((𝐹f 𝑅𝐺) “ 𝐷) = 𝑝 ∈ (𝑅𝐷)((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})))
6 inundif 4433 . . . . 5 (((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺)) ∪ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) = (𝑅𝐷)
7 iuneq1 4966 . . . . 5 ((((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺)) ∪ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) = (𝑅𝐷) → 𝑝 ∈ (((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺)) ∪ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺)))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = 𝑝 ∈ (𝑅𝐷)((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})))
86, 7ax-mp 5 . . . 4 𝑝 ∈ (((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺)) ∪ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺)))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = 𝑝 ∈ (𝑅𝐷)((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)}))
9 iunxun 5051 . . . 4 𝑝 ∈ (((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺)) ∪ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺)))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ( 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) ∪ 𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})))
108, 9eqtr3i 2787 . . 3 𝑝 ∈ (𝑅𝐷)((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ( 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) ∪ 𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})))
115, 10eqtrdi 2813 . 2 (𝜑 → ((𝐹f 𝑅𝐺) “ 𝐷) = ( 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) ∪ 𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)}))))
12 simpr 488 . . . . . . . . . . 11 ((𝜑𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) → 𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺)))
1312eldifbd 3917 . . . . . . . . . 10 ((𝜑𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) → ¬ 𝑝 ∈ (ran 𝐹 × ran 𝐺))
14 cnvimass 6071 . . . . . . . . . . . . . 14 (𝑅𝐷) ⊆ dom 𝑅
154fndmd 6626 . . . . . . . . . . . . . 14 (𝜑 → dom 𝑅 = (𝐵 × 𝐶))
1614, 15sseqtrid 3978 . . . . . . . . . . . . 13 (𝜑 → (𝑅𝐷) ⊆ (𝐵 × 𝐶))
1716ssdifssd 4100 . . . . . . . . . . . 12 (𝜑 → ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺)) ⊆ (𝐵 × 𝐶))
1817sselda 3936 . . . . . . . . . . 11 ((𝜑𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) → 𝑝 ∈ (𝐵 × 𝐶))
19 1st2nd2 8009 . . . . . . . . . . 11 (𝑝 ∈ (𝐵 × 𝐶) → 𝑝 = ⟨(1st𝑝), (2nd𝑝)⟩)
20 elxp6 8004 . . . . . . . . . . . 12 (𝑝 ∈ (ran 𝐹 × ran 𝐺) ↔ (𝑝 = ⟨(1st𝑝), (2nd𝑝)⟩ ∧ ((1st𝑝) ∈ ran 𝐹 ∧ (2nd𝑝) ∈ ran 𝐺)))
2120simplbi2 504 . . . . . . . . . . 11 (𝑝 = ⟨(1st𝑝), (2nd𝑝)⟩ → (((1st𝑝) ∈ ran 𝐹 ∧ (2nd𝑝) ∈ ran 𝐺) → 𝑝 ∈ (ran 𝐹 × ran 𝐺)))
2218, 19, 213syl 18 . . . . . . . . . 10 ((𝜑𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) → (((1st𝑝) ∈ ran 𝐹 ∧ (2nd𝑝) ∈ ran 𝐺) → 𝑝 ∈ (ran 𝐹 × ran 𝐺)))
2313, 22mtod 200 . . . . . . . . 9 ((𝜑𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) → ¬ ((1st𝑝) ∈ ran 𝐹 ∧ (2nd𝑝) ∈ ran 𝐺))
24 ianor 995 . . . . . . . . 9 (¬ ((1st𝑝) ∈ ran 𝐹 ∧ (2nd𝑝) ∈ ran 𝐺) ↔ (¬ (1st𝑝) ∈ ran 𝐹 ∨ ¬ (2nd𝑝) ∈ ran 𝐺))
2523, 24sylib 220 . . . . . . . 8 ((𝜑𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) → (¬ (1st𝑝) ∈ ran 𝐹 ∨ ¬ (2nd𝑝) ∈ ran 𝐺))
26 disjsn 4670 . . . . . . . . 9 ((ran 𝐹 ∩ {(1st𝑝)}) = ∅ ↔ ¬ (1st𝑝) ∈ ran 𝐹)
27 disjsn 4670 . . . . . . . . 9 ((ran 𝐺 ∩ {(2nd𝑝)}) = ∅ ↔ ¬ (2nd𝑝) ∈ ran 𝐺)
2826, 27orbi12i 925 . . . . . . . 8 (((ran 𝐹 ∩ {(1st𝑝)}) = ∅ ∨ (ran 𝐺 ∩ {(2nd𝑝)}) = ∅) ↔ (¬ (1st𝑝) ∈ ran 𝐹 ∨ ¬ (2nd𝑝) ∈ ran 𝐺))
2925, 28sylibr 236 . . . . . . 7 ((𝜑𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) → ((ran 𝐹 ∩ {(1st𝑝)}) = ∅ ∨ (ran 𝐺 ∩ {(2nd𝑝)}) = ∅))
301ffnd 6692 . . . . . . . . 9 (𝜑𝐹 Fn 𝐴)
31 dffn3 6704 . . . . . . . . 9 (𝐹 Fn 𝐴𝐹:𝐴⟶ran 𝐹)
3230, 31sylib 220 . . . . . . . 8 (𝜑𝐹:𝐴⟶ran 𝐹)
332ffnd 6692 . . . . . . . . . 10 (𝜑𝐺 Fn 𝐴)
34 dffn3 6704 . . . . . . . . . 10 (𝐺 Fn 𝐴𝐺:𝐴⟶ran 𝐺)
3533, 34sylib 220 . . . . . . . . 9 (𝜑𝐺:𝐴⟶ran 𝐺)
3635adantr 484 . . . . . . . 8 ((𝜑𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) → 𝐺:𝐴⟶ran 𝐺)
37 fimacnvdisj 6742 . . . . . . . . . . 11 ((𝐹:𝐴⟶ran 𝐹 ∧ (ran 𝐹 ∩ {(1st𝑝)}) = ∅) → (𝐹 “ {(1st𝑝)}) = ∅)
38 ineq1 4165 . . . . . . . . . . . 12 ((𝐹 “ {(1st𝑝)}) = ∅ → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = (∅ ∩ (𝐺 “ {(2nd𝑝)})))
39 0in 4351 . . . . . . . . . . . 12 (∅ ∩ (𝐺 “ {(2nd𝑝)})) = ∅
4038, 39eqtrdi 2813 . . . . . . . . . . 11 ((𝐹 “ {(1st𝑝)}) = ∅ → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ∅)
4137, 40syl 17 . . . . . . . . . 10 ((𝐹:𝐴⟶ran 𝐹 ∧ (ran 𝐹 ∩ {(1st𝑝)}) = ∅) → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ∅)
4241ex 416 . . . . . . . . 9 (𝐹:𝐴⟶ran 𝐹 → ((ran 𝐹 ∩ {(1st𝑝)}) = ∅ → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ∅))
43 fimacnvdisj 6742 . . . . . . . . . . 11 ((𝐺:𝐴⟶ran 𝐺 ∧ (ran 𝐺 ∩ {(2nd𝑝)}) = ∅) → (𝐺 “ {(2nd𝑝)}) = ∅)
44 ineq2 4166 . . . . . . . . . . . 12 ((𝐺 “ {(2nd𝑝)}) = ∅ → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ((𝐹 “ {(1st𝑝)}) ∩ ∅))
45 in0 4349 . . . . . . . . . . . 12 ((𝐹 “ {(1st𝑝)}) ∩ ∅) = ∅
4644, 45eqtrdi 2813 . . . . . . . . . . 11 ((𝐺 “ {(2nd𝑝)}) = ∅ → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ∅)
4743, 46syl 17 . . . . . . . . . 10 ((𝐺:𝐴⟶ran 𝐺 ∧ (ran 𝐺 ∩ {(2nd𝑝)}) = ∅) → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ∅)
4847ex 416 . . . . . . . . 9 (𝐺:𝐴⟶ran 𝐺 → ((ran 𝐺 ∩ {(2nd𝑝)}) = ∅ → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ∅))
4942, 48jaao 967 . . . . . . . 8 ((𝐹:𝐴⟶ran 𝐹𝐺:𝐴⟶ran 𝐺) → (((ran 𝐹 ∩ {(1st𝑝)}) = ∅ ∨ (ran 𝐺 ∩ {(2nd𝑝)}) = ∅) → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ∅))
5032, 36, 49syl2an2r 695 . . . . . . 7 ((𝜑𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) → (((ran 𝐹 ∩ {(1st𝑝)}) = ∅ ∨ (ran 𝐺 ∩ {(2nd𝑝)}) = ∅) → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ∅))
5129, 50mpd 15 . . . . . 6 ((𝜑𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))) → ((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ∅)
5251iuneq2dv 4974 . . . . 5 (𝜑 𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = 𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))∅)
53 iun0 5019 . . . . 5 𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))∅ = ∅
5452, 53eqtrdi 2813 . . . 4 (𝜑 𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) = ∅)
5554uneq2d 4121 . . 3 (𝜑 → ( 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) ∪ 𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)}))) = ( 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) ∪ ∅))
56 un0 4348 . . 3 ( 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) ∪ ∅) = 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)}))
5755, 56eqtrdi 2813 . 2 (𝜑 → ( 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})) ∪ 𝑝 ∈ ((𝑅𝐷) ∖ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)}))) = 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})))
5811, 57eqtrd 2797 1 (𝜑 → ((𝐹f 𝑅𝐺) “ 𝐷) = 𝑝 ∈ ((𝑅𝐷) ∩ (ran 𝐹 × ran 𝐺))((𝐹 “ {(1st𝑝)}) ∩ (𝐺 “ {(2nd𝑝)})))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wa 399  wo 858   = wceq 1560  wcel 2142  cdif 3901  cun 3902  cin 3903  c0 4285  {csn 4582  cop 4588   ciun 4949   × cxp 5645  ccnv 5646  dom cdm 5647  ran crn 5648  cima 5650   Fn wfn 6516  wf 6517  cfv 6521  (class class class)co 7396  f cof 7658  1st c1st 7968  2nd c2nd 7969
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1815  ax-4 1829  ax-5 1930  ax-6 1987  ax-7 2028  ax-8 2144  ax-9 2152  ax-10 2175  ax-11 2191  ax-12 2212  ax-ext 2734  ax-rep 5227  ax-sep 5246  ax-nul 5256  ax-pr 5390  ax-un 7718
This theorem depends on definitions:  df-bi 209  df-an 400  df-or 859  df-3an 1100  df-tru 1563  df-fal 1573  df-ex 1800  df-nf 1804  df-sb 2091  df-mo 2566  df-eu 2596  df-clab 2741  df-cleq 2754  df-clel 2837  df-nfc 2911  df-ne 2958  df-ral 3077  df-rex 3087  df-reu 3368  df-rab 3415  df-v 3456  df-sbc 3745  df-csb 3853  df-dif 3907  df-un 3909  df-in 3911  df-ss 3921  df-nul 4286  df-if 4481  df-sn 4583  df-pr 4585  df-op 4589  df-uni 4866  df-iun 4951  df-br 5101  df-opab 5163  df-mpt 5182  df-id 5542  df-xp 5653  df-rel 5654  df-cnv 5655  df-co 5656  df-dm 5657  df-rn 5658  df-res 5659  df-ima 5660  df-iota 6477  df-fun 6523  df-fn 6524  df-f 6525  df-f1 6526  df-fo 6527  df-f1o 6528  df-fv 6529  df-ov 7399  df-oprab 7400  df-mpo 7401  df-of 7660  df-1st 7970  df-2nd 7971
This theorem is referenced by:  sibfof  34634
  Copyright terms: Public domain W3C validator