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

Theorem isphtpy 23579
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 21843 . . . . 5 (𝐹 ∈ (II Cn 𝐽) → 𝐽 ∈ Top)
3 oveq2 7158 . . . . . . 7 (𝑗 = 𝐽 → (II Cn 𝑗) = (II Cn 𝐽))
4 oveq2 7158 . . . . . . . . 9 (𝑗 = 𝐽 → (II Htpy 𝑗) = (II Htpy 𝐽))
54oveqd 7167 . . . . . . . 8 (𝑗 = 𝐽 → (𝑓(II Htpy 𝑗)𝑔) = (𝑓(II Htpy 𝐽)𝑔))
65rabeqdv 3484 . . . . . . 7 (𝑗 = 𝐽 → { ∈ (𝑓(II Htpy 𝑗)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))} = { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))})
73, 3, 6mpoeq123dv 7223 . . . . . 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 23569 . . . . . 6 PHtpy = (𝑗 ∈ Top ↦ (𝑓 ∈ (II Cn 𝑗), 𝑔 ∈ (II Cn 𝑗) ↦ { ∈ (𝑓(II Htpy 𝑗)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))}))
9 ovex 7183 . . . . . . 7 (II Cn 𝐽) ∈ V
109, 9mpoex 7771 . . . . . 6 (𝑓 ∈ (II Cn 𝐽), 𝑔 ∈ (II Cn 𝐽) ↦ { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))}) ∈ V
117, 8, 10fvmpt 6762 . . . . 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 7159 . . . . . 6 ((𝑓 = 𝐹𝑔 = 𝐺) → (𝑓(II Htpy 𝐽)𝑔) = (𝐹(II Htpy 𝐽)𝐺))
14 simpl 485 . . . . . . . . . 10 ((𝑓 = 𝐹𝑔 = 𝐺) → 𝑓 = 𝐹)
1514fveq1d 6666 . . . . . . . . 9 ((𝑓 = 𝐹𝑔 = 𝐺) → (𝑓‘0) = (𝐹‘0))
1615eqeq2d 2832 . . . . . . . 8 ((𝑓 = 𝐹𝑔 = 𝐺) → ((0𝑠) = (𝑓‘0) ↔ (0𝑠) = (𝐹‘0)))
1714fveq1d 6666 . . . . . . . . 9 ((𝑓 = 𝐹𝑔 = 𝐺) → (𝑓‘1) = (𝐹‘1))
1817eqeq2d 2832 . . . . . . . 8 ((𝑓 = 𝐹𝑔 = 𝐺) → ((1𝑠) = (𝑓‘1) ↔ (1𝑠) = (𝐹‘1)))
1916, 18anbi12d 632 . . . . . . 7 ((𝑓 = 𝐹𝑔 = 𝐺) → (((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1)) ↔ ((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))))
2019ralbidv 3197 . . . . . 6 ((𝑓 = 𝐹𝑔 = 𝐺) → (∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1)) ↔ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))))
2113, 20rabeqbidv 3485 . . . . 5 ((𝑓 = 𝐹𝑔 = 𝐺) → { ∈ (𝑓(II Htpy 𝐽)𝑔) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝑓‘0) ∧ (1𝑠) = (𝑓‘1))} = { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))})
2221adantl 484 . . . 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 7183 . . . . . 6 (𝐹(II Htpy 𝐽)𝐺) ∈ V
2524rabex 5227 . . . . 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 7296 . . 3 (𝜑 → (𝐹(PHtpy‘𝐽)𝐺) = { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))})
2827eleq2d 2898 . 2 (𝜑 → (𝐻 ∈ (𝐹(PHtpy‘𝐽)𝐺) ↔ 𝐻 ∈ { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))}))
29 oveq 7156 . . . . . 6 ( = 𝐻 → (0𝑠) = (0𝐻𝑠))
3029eqeq1d 2823 . . . . 5 ( = 𝐻 → ((0𝑠) = (𝐹‘0) ↔ (0𝐻𝑠) = (𝐹‘0)))
31 oveq 7156 . . . . . 6 ( = 𝐻 → (1𝑠) = (1𝐻𝑠))
3231eqeq1d 2823 . . . . 5 ( = 𝐻 → ((1𝑠) = (𝐹‘1) ↔ (1𝐻𝑠) = (𝐹‘1)))
3330, 32anbi12d 632 . . . 4 ( = 𝐻 → (((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1)) ↔ ((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1))))
3433ralbidv 3197 . . 3 ( = 𝐻 → (∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1)) ↔ ∀𝑠 ∈ (0[,]1)((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1))))
3534elrab 3679 . 2 (𝐻 ∈ { ∈ (𝐹(II Htpy 𝐽)𝐺) ∣ ∀𝑠 ∈ (0[,]1)((0𝑠) = (𝐹‘0) ∧ (1𝑠) = (𝐹‘1))} ↔ (𝐻 ∈ (𝐹(II Htpy 𝐽)𝐺) ∧ ∀𝑠 ∈ (0[,]1)((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1))))
3628, 35syl6bb 289 1 (𝜑 → (𝐻 ∈ (𝐹(PHtpy‘𝐽)𝐺) ↔ (𝐻 ∈ (𝐹(II Htpy 𝐽)𝐺) ∧ ∀𝑠 ∈ (0[,]1)((0𝐻𝑠) = (𝐹‘0) ∧ (1𝐻𝑠) = (𝐹‘1)))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 208  wa 398   = wceq 1533  wcel 2110  wral 3138  {crab 3142  Vcvv 3494  cfv 6349  (class class class)co 7150  cmpo 7152  0cc0 10531  1c1 10532  [,]cicc 12735  Topctop 21495   Cn ccn 21826  IIcii 23477   Htpy chtpy 23565  PHtpycphtpy 23566
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1792  ax-4 1806  ax-5 1907  ax-6 1966  ax-7 2011  ax-8 2112  ax-9 2120  ax-10 2141  ax-11 2157  ax-12 2173  ax-ext 2793  ax-rep 5182  ax-sep 5195  ax-nul 5202  ax-pow 5258  ax-pr 5321  ax-un 7455
This theorem depends on definitions:  df-bi 209  df-an 399  df-or 844  df-3an 1085  df-tru 1536  df-ex 1777  df-nf 1781  df-sb 2066  df-mo 2618  df-eu 2650  df-clab 2800  df-cleq 2814  df-clel 2893  df-nfc 2963  df-ne 3017  df-ral 3143  df-rex 3144  df-reu 3145  df-rab 3147  df-v 3496  df-sbc 3772  df-csb 3883  df-dif 3938  df-un 3940  df-in 3942  df-ss 3951  df-nul 4291  df-if 4467  df-pw 4540  df-sn 4561  df-pr 4563  df-op 4567  df-uni 4832  df-iun 4913  df-br 5059  df-opab 5121  df-mpt 5139  df-id 5454  df-xp 5555  df-rel 5556  df-cnv 5557  df-co 5558  df-dm 5559  df-rn 5560  df-res 5561  df-ima 5562  df-iota 6308  df-fun 6351  df-fn 6352  df-f 6353  df-f1 6354  df-fo 6355  df-f1o 6356  df-fv 6357  df-ov 7153  df-oprab 7154  df-mpo 7155  df-1st 7683  df-2nd 7684  df-map 8402  df-top 21496  df-topon 21513  df-cn 21829  df-phtpy 23569
This theorem is referenced by:  phtpyhtpy  23580  phtpyi  23582  isphtpyd  23584
  Copyright terms: Public domain W3C validator