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

Theorem isphtpy 24488
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 22736 . . . . 5 (𝐹 ∈ (II Cn 𝐽) → 𝐽 ∈ Top)
3 oveq2 7413 . . . . . . 7 (𝑗 = 𝐽 → (II Cn 𝑗) = (II Cn 𝐽))
4 oveq2 7413 . . . . . . . . 9 (𝑗 = 𝐽 → (II Htpy 𝑗) = (II Htpy 𝐽))
54oveqd 7422 . . . . . . . 8 (𝑗 = 𝐽 → (𝑓(II Htpy 𝑗)𝑔) = (𝑓(II Htpy 𝐽)𝑔))
65rabeqdv 3447 . . . . . . 7 (𝑗 = 𝐽 → { ∈ (𝑓(II Htpy 𝑗)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))} = { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))})
73, 3, 6mpoeq123dv 7480 . . . . . 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 24478 . . . . . 6 PHtpy = (𝑗 ∈ Top ↦ (𝑓 ∈ (II Cn 𝑗), 𝑔 ∈ (II Cn 𝑗) ↦ { ∈ (𝑓(II Htpy 𝑗)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))}))
9 ovex 7438 . . . . . . 7 (II Cn 𝐽) ∈ V
109, 9mpoex 8062 . . . . . 6 (𝑓 ∈ (II Cn 𝐽), 𝑔 ∈ (II Cn 𝐽) ↦ { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))}) ∈ V
117, 8, 10fvmpt 6995 . . . . 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 7414 . . . . . 6 ((𝑓 = 𝐹𝑔 = 𝐺) → (𝑓(II Htpy 𝐽)𝑔) = (𝐹(II Htpy 𝐽)𝐺))
14 simpl 483 . . . . . . . . . 10 ((𝑓 = 𝐹𝑔 = 𝐺) → 𝑓 = 𝐹)
1514fveq1d 6890 . . . . . . . . 9 ((𝑓 = 𝐹𝑔 = 𝐺) → (𝑓‘0) = (𝐹‘0))
1615eqeq2d 2743 . . . . . . . 8 ((𝑓 = 𝐹𝑔 = 𝐺) → ((0𝑠) = (𝑓‘0) ↔ (0𝑠) = (𝐹‘0)))
1714fveq1d 6890 . . . . . . . . 9 ((𝑓 = 𝐹𝑔 = 𝐺) → (𝑓‘1) = (𝐹‘1))
1817eqeq2d 2743 . . . . . . . 8 ((𝑓 = 𝐹𝑔 = 𝐺) → ((1𝑠) = (𝑓‘1) ↔ (1𝑠) = (𝐹‘1)))
1916, 18anbi12d 631 . . . . . . 7 ((𝑓 = 𝐹𝑔 = 𝐺) → (((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1)) ↔ ((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))))
2019ralbidv 3177 . . . . . 6 ((𝑓 = 𝐹𝑔 = 𝐺) → (∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1)) ↔ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))))
2113, 20rabeqbidv 3449 . . . . 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 7438 . . . . . 6 (𝐹(II Htpy 𝐽)𝐺) ∈ V
2524rabex 5331 . . . . 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 7556 . . 3 (𝜑 → (𝐹(PHtpy‘𝐽)𝐺) = { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))})
2827eleq2d 2819 . 2 (𝜑 → (𝐻 ∈ (𝐹(PHtpy‘𝐽)𝐺) ↔ 𝐻 ∈ { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))}))
29 oveq 7411 . . . . . 6 ( = 𝐻 → (0𝑠) = (0𝐻𝑠))
3029eqeq1d 2734 . . . . 5 ( = 𝐻 → ((0𝑠) = (𝐹‘0) ↔ (0𝐻𝑠) = (𝐹‘0)))
31 oveq 7411 . . . . . 6 ( = 𝐻 → (1𝑠) = (1𝐻𝑠))
3231eqeq1d 2734 . . . . 5 ( = 𝐻 → ((1𝑠) = (𝐹‘1) ↔ (1𝐻𝑠) = (𝐹‘1)))
3330, 32anbi12d 631 . . . 4 ( = 𝐻 → (((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1)) ↔ ((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1))))
3433ralbidv 3177 . . 3 ( = 𝐻 → (∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1)) ↔ ∀𝑠 ∈ (0[,]1)((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1))))
3534elrab 3682 . 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 3061  {crab 3432  Vcvv 3474  cfv 6540  (class class class)co 7405  cmpo 7407  0cc0 11106  1c1 11107  [,]cicc 13323  Topctop 22386   Cn ccn 22719  IIcii 24382   Htpy chtpy 24474  PHtpycphtpy 24475
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 2703  ax-rep 5284  ax-sep 5298  ax-nul 5305  ax-pow 5362  ax-pr 5426  ax-un 7721
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 2534  df-eu 2563  df-clab 2710  df-cleq 2724  df-clel 2810  df-nfc 2885  df-ne 2941  df-ral 3062  df-rex 3071  df-reu 3377  df-rab 3433  df-v 3476  df-sbc 3777  df-csb 3893  df-dif 3950  df-un 3952  df-in 3954  df-ss 3964  df-nul 4322  df-if 4528  df-pw 4603  df-sn 4628  df-pr 4630  df-op 4634  df-uni 4908  df-iun 4998  df-br 5148  df-opab 5210  df-mpt 5231  df-id 5573  df-xp 5681  df-rel 5682  df-cnv 5683  df-co 5684  df-dm 5685  df-rn 5686  df-res 5687  df-ima 5688  df-iota 6492  df-fun 6542  df-fn 6543  df-f 6544  df-f1 6545  df-fo 6546  df-f1o 6547  df-fv 6548  df-ov 7408  df-oprab 7409  df-mpo 7410  df-1st 7971  df-2nd 7972  df-map 8818  df-top 22387  df-topon 22404  df-cn 22722  df-phtpy 24478
This theorem is referenced by:  phtpyhtpy  24489  phtpyi  24491  isphtpyd  24493
  Copyright terms: Public domain W3C validator