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

Theorem isphtpy 24296
Description: Membership in the class of path homotopies between two continuous functions. (Contributed by Jeff Madsen, 2-Sep-2009.) (Revised by Mario Carneiro, 23-Feb-2015.)
Hypotheses
Ref Expression
isphtpy.2 (𝜑𝐹 ∈ (II Cn 𝐽))
isphtpy.3 (𝜑𝐺 ∈ (II Cn 𝐽))
Assertion
Ref Expression
isphtpy (𝜑 → (𝐻 ∈ (𝐹(PHtpy‘𝐽)𝐺) ↔ (𝐻 ∈ (𝐹(II Htpy 𝐽)𝐺) ∧ ∀𝑠 ∈ (0[,]1)((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1)))))
Distinct variable groups:   𝐹,𝑠   𝐺,𝑠   𝐻,𝑠   𝐽,𝑠   𝜑,𝑠

Proof of Theorem isphtpy
Dummy variables 𝑓 𝑔 𝑗 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 isphtpy.2 . . . . 5 (𝜑𝐹 ∈ (II Cn 𝐽))
2 cntop2 22544 . . . . 5 (𝐹 ∈ (II Cn 𝐽) → 𝐽 ∈ Top)
3 oveq2 7359 . . . . . . 7 (𝑗 = 𝐽 → (II Cn 𝑗) = (II Cn 𝐽))
4 oveq2 7359 . . . . . . . . 9 (𝑗 = 𝐽 → (II Htpy 𝑗) = (II Htpy 𝐽))
54oveqd 7368 . . . . . . . 8 (𝑗 = 𝐽 → (𝑓(II Htpy 𝑗)𝑔) = (𝑓(II Htpy 𝐽)𝑔))
65rabeqdv 3420 . . . . . . 7 (𝑗 = 𝐽 → { ∈ (𝑓(II Htpy 𝑗)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))} = { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))})
73, 3, 6mpoeq123dv 7426 . . . . . 6 (𝑗 = 𝐽 → (𝑓 ∈ (II Cn 𝑗), 𝑔 ∈ (II Cn 𝑗) ↦ { ∈ (𝑓(II Htpy 𝑗)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))}) = (𝑓 ∈ (II Cn 𝐽), 𝑔 ∈ (II Cn 𝐽) ↦ { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))}))
8 df-phtpy 24286 . . . . . 6 PHtpy = (𝑗 ∈ Top ↦ (𝑓 ∈ (II Cn 𝑗), 𝑔 ∈ (II Cn 𝑗) ↦ { ∈ (𝑓(II Htpy 𝑗)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))}))
9 ovex 7384 . . . . . . 7 (II Cn 𝐽) ∈ V
109, 9mpoex 8004 . . . . . 6 (𝑓 ∈ (II Cn 𝐽), 𝑔 ∈ (II Cn 𝐽) ↦ { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))}) ∈ V
117, 8, 10fvmpt 6945 . . . . 5 (𝐽 ∈ Top → (PHtpy‘𝐽) = (𝑓 ∈ (II Cn 𝐽), 𝑔 ∈ (II Cn 𝐽) ↦ { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))}))
121, 2, 113syl 18 . . . 4 (𝜑 → (PHtpy‘𝐽) = (𝑓 ∈ (II Cn 𝐽), 𝑔 ∈ (II Cn 𝐽) ↦ { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))}))
13 oveq12 7360 . . . . . 6 ((𝑓 = 𝐹𝑔 = 𝐺) → (𝑓(II Htpy 𝐽)𝑔) = (𝐹(II Htpy 𝐽)𝐺))
14 simpl 483 . . . . . . . . . 10 ((𝑓 = 𝐹𝑔 = 𝐺) → 𝑓 = 𝐹)
1514fveq1d 6841 . . . . . . . . 9 ((𝑓 = 𝐹𝑔 = 𝐺) → (𝑓‘0) = (𝐹‘0))
1615eqeq2d 2748 . . . . . . . 8 ((𝑓 = 𝐹𝑔 = 𝐺) → ((0𝑠) = (𝑓‘0) ↔ (0𝑠) = (𝐹‘0)))
1714fveq1d 6841 . . . . . . . . 9 ((𝑓 = 𝐹𝑔 = 𝐺) → (𝑓‘1) = (𝐹‘1))
1817eqeq2d 2748 . . . . . . . 8 ((𝑓 = 𝐹𝑔 = 𝐺) → ((1𝑠) = (𝑓‘1) ↔ (1𝑠) = (𝐹‘1)))
1916, 18anbi12d 631 . . . . . . 7 ((𝑓 = 𝐹𝑔 = 𝐺) → (((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1)) ↔ ((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))))
2019ralbidv 3172 . . . . . 6 ((𝑓 = 𝐹𝑔 = 𝐺) → (∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1)) ↔ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))))
2113, 20rabeqbidv 3422 . . . . 5 ((𝑓 = 𝐹𝑔 = 𝐺) → { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))} = { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))})
2221adantl 482 . . . 4 ((𝜑 ∧ (𝑓 = 𝐹𝑔 = 𝐺)) → { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))} = { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))})
23 isphtpy.3 . . . 4 (𝜑𝐺 ∈ (II Cn 𝐽))
24 ovex 7384 . . . . . 6 (𝐹(II Htpy 𝐽)𝐺) ∈ V
2524rabex 5287 . . . . 5 { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))} ∈ V
2625a1i 11 . . . 4 (𝜑 → { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))} ∈ V)
2712, 22, 1, 23, 26ovmpod 7501 . . 3 (𝜑 → (𝐹(PHtpy‘𝐽)𝐺) = { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))})
2827eleq2d 2823 . 2 (𝜑 → (𝐻 ∈ (𝐹(PHtpy‘𝐽)𝐺) ↔ 𝐻 ∈ { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))}))
29 oveq 7357 . . . . . 6 ( = 𝐻 → (0𝑠) = (0𝐻𝑠))
3029eqeq1d 2739 . . . . 5 ( = 𝐻 → ((0𝑠) = (𝐹‘0) ↔ (0𝐻𝑠) = (𝐹‘0)))
31 oveq 7357 . . . . . 6 ( = 𝐻 → (1𝑠) = (1𝐻𝑠))
3231eqeq1d 2739 . . . . 5 ( = 𝐻 → ((1𝑠) = (𝐹‘1) ↔ (1𝐻𝑠) = (𝐹‘1)))
3330, 32anbi12d 631 . . . 4 ( = 𝐻 → (((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1)) ↔ ((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1))))
3433ralbidv 3172 . . 3 ( = 𝐻 → (∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1)) ↔ ∀𝑠 ∈ (0[,]1)((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1))))
3534elrab 3643 . 2 (𝐻 ∈ { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))} ↔ (𝐻 ∈ (𝐹(II Htpy 𝐽)𝐺) ∧ ∀𝑠 ∈ (0[,]1)((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1))))
3628, 35bitrdi 286 1 (𝜑 → (𝐻 ∈ (𝐹(PHtpy‘𝐽)𝐺) ↔ (𝐻 ∈ (𝐹(II Htpy 𝐽)𝐺) ∧ ∀𝑠 ∈ (0[,]1)((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1)))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 205  wa 396   = wceq 1541  wcel 2106  wral 3062  {crab 3405  Vcvv 3443  cfv 6493  (class class class)co 7351  cmpo 7353  0cc0 11009  1c1 11010  [,]cicc 13221  Topctop 22194   Cn ccn 22527  IIcii 24190   Htpy chtpy 24282  PHtpycphtpy 24283
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1913  ax-6 1971  ax-7 2011  ax-8 2108  ax-9 2116  ax-10 2137  ax-11 2154  ax-12 2171  ax-ext 2708  ax-rep 5240  ax-sep 5254  ax-nul 5261  ax-pow 5318  ax-pr 5382  ax-un 7664
This theorem depends on definitions:  df-bi 206  df-an 397  df-or 846  df-3an 1089  df-tru 1544  df-fal 1554  df-ex 1782  df-nf 1786  df-sb 2068  df-mo 2539  df-eu 2568  df-clab 2715  df-cleq 2729  df-clel 2815  df-nfc 2887  df-ne 2942  df-ral 3063  df-rex 3072  df-reu 3352  df-rab 3406  df-v 3445  df-sbc 3738  df-csb 3854  df-dif 3911  df-un 3913  df-in 3915  df-ss 3925  df-nul 4281  df-if 4485  df-pw 4560  df-sn 4585  df-pr 4587  df-op 4591  df-uni 4864  df-iun 4954  df-br 5104  df-opab 5166  df-mpt 5187  df-id 5529  df-xp 5637  df-rel 5638  df-cnv 5639  df-co 5640  df-dm 5641  df-rn 5642  df-res 5643  df-ima 5644  df-iota 6445  df-fun 6495  df-fn 6496  df-f 6497  df-f1 6498  df-fo 6499  df-f1o 6500  df-fv 6501  df-ov 7354  df-oprab 7355  df-mpo 7356  df-1st 7913  df-2nd 7914  df-map 8725  df-top 22195  df-topon 22212  df-cn 22530  df-phtpy 24286
This theorem is referenced by:  phtpyhtpy  24297  phtpyi  24299  isphtpyd  24301
  Copyright terms: Public domain W3C validator