| Metamath Proof Explorer |
< Previous
Next >
Nearby theorems |
||
| Mirrors > Home > MPE Home > Th. List > eupth2lem3 | Structured version Visualization version GIF version | ||
| Description: Lemma for eupth2 30327. (Contributed by Mario Carneiro, 8-Apr-2015.) (Revised by AV, 26-Feb-2021.) |
| Ref | Expression |
|---|---|
| eupth2.v | ⊢ 𝑉 = (Vtx‘𝐺) |
| eupth2.i | ⊢ 𝐼 = (iEdg‘𝐺) |
| eupth2.g | ⊢ (𝜑 → 𝐺 ∈ UPGraph) |
| eupth2.f | ⊢ (𝜑 → Fun 𝐼) |
| eupth2.p | ⊢ (𝜑 → 𝐹(EulerPaths‘𝐺)𝑃) |
| eupth2.h | ⊢ 𝐻 = 〈𝑉, (𝐼 ↾ (𝐹 “ (0..^𝑁)))〉 |
| eupth2.x | ⊢ 𝑋 = 〈𝑉, (𝐼 ↾ (𝐹 “ (0..^(𝑁 + 1))))〉 |
| eupth2.n | ⊢ (𝜑 → 𝑁 ∈ ℕ0) |
| eupth2.l | ⊢ (𝜑 → (𝑁 + 1) ≤ (♯‘𝐹)) |
| eupth2.u | ⊢ (𝜑 → 𝑈 ∈ 𝑉) |
| eupth2.o | ⊢ (𝜑 → {𝑥 ∈ 𝑉 ∣ ¬ 2 ∥ ((VtxDeg‘𝐻)‘𝑥)} = if((𝑃‘0) = (𝑃‘𝑁), ∅, {(𝑃‘0), (𝑃‘𝑁)})) |
| Ref | Expression |
|---|---|
| eupth2lem3 | ⊢ (𝜑 → (¬ 2 ∥ ((VtxDeg‘𝑋)‘𝑈) ↔ 𝑈 ∈ if((𝑃‘0) = (𝑃‘(𝑁 + 1)), ∅, {(𝑃‘0), (𝑃‘(𝑁 + 1))}))) |
| Step | Hyp | Ref | Expression |
|---|---|---|---|
| 1 | eupth2.v | . 2 ⊢ 𝑉 = (Vtx‘𝐺) | |
| 2 | eupth2.i | . 2 ⊢ 𝐼 = (iEdg‘𝐺) | |
| 3 | eupth2.f | . 2 ⊢ (𝜑 → Fun 𝐼) | |
| 4 | eupth2.n | . . 3 ⊢ (𝜑 → 𝑁 ∈ ℕ0) | |
| 5 | eupth2.p | . . . 4 ⊢ (𝜑 → 𝐹(EulerPaths‘𝐺)𝑃) | |
| 6 | eupthiswlk 30300 | . . . 4 ⊢ (𝐹(EulerPaths‘𝐺)𝑃 → 𝐹(Walks‘𝐺)𝑃) | |
| 7 | wlkcl 29702 | . . . 4 ⊢ (𝐹(Walks‘𝐺)𝑃 → (♯‘𝐹) ∈ ℕ0) | |
| 8 | 5, 6, 7 | 3syl 18 | . . 3 ⊢ (𝜑 → (♯‘𝐹) ∈ ℕ0) |
| 9 | eupth2.l | . . 3 ⊢ (𝜑 → (𝑁 + 1) ≤ (♯‘𝐹)) | |
| 10 | nn0p1elfzo 13648 | . . 3 ⊢ ((𝑁 ∈ ℕ0 ∧ (♯‘𝐹) ∈ ℕ0 ∧ (𝑁 + 1) ≤ (♯‘𝐹)) → 𝑁 ∈ (0..^(♯‘𝐹))) | |
| 11 | 4, 8, 9, 10 | syl3anc 1379 | . 2 ⊢ (𝜑 → 𝑁 ∈ (0..^(♯‘𝐹))) |
| 12 | eupth2.u | . 2 ⊢ (𝜑 → 𝑈 ∈ 𝑉) | |
| 13 | eupthistrl 30299 | . . 3 ⊢ (𝐹(EulerPaths‘𝐺)𝑃 → 𝐹(Trails‘𝐺)𝑃) | |
| 14 | 5, 13 | syl 17 | . 2 ⊢ (𝜑 → 𝐹(Trails‘𝐺)𝑃) |
| 15 | eupth2.h | . . . . 5 ⊢ 𝐻 = 〈𝑉, (𝐼 ↾ (𝐹 “ (0..^𝑁)))〉 | |
| 16 | 15 | fveq2i 6830 | . . . 4 ⊢ (Vtx‘𝐻) = (Vtx‘〈𝑉, (𝐼 ↾ (𝐹 “ (0..^𝑁)))〉) |
| 17 | 1 | fvexi 6841 | . . . . 5 ⊢ 𝑉 ∈ V |
| 18 | 2 | fvexi 6841 | . . . . . 6 ⊢ 𝐼 ∈ V |
| 19 | 18 | resex 5981 | . . . . 5 ⊢ (𝐼 ↾ (𝐹 “ (0..^𝑁))) ∈ V |
| 20 | 17, 19 | opvtxfvi 29096 | . . . 4 ⊢ (Vtx‘〈𝑉, (𝐼 ↾ (𝐹 “ (0..^𝑁)))〉) = 𝑉 |
| 21 | 16, 20 | eqtri 2762 | . . 3 ⊢ (Vtx‘𝐻) = 𝑉 |
| 22 | 21 | a1i 11 | . 2 ⊢ (𝜑 → (Vtx‘𝐻) = 𝑉) |
| 23 | snex 5368 | . . . 4 ⊢ {〈(𝐹‘𝑁), (𝐼‘(𝐹‘𝑁))〉} ∈ V | |
| 24 | 17, 23 | opvtxfvi 29096 | . . 3 ⊢ (Vtx‘〈𝑉, {〈(𝐹‘𝑁), (𝐼‘(𝐹‘𝑁))〉}〉) = 𝑉 |
| 25 | 24 | a1i 11 | . 2 ⊢ (𝜑 → (Vtx‘〈𝑉, {〈(𝐹‘𝑁), (𝐼‘(𝐹‘𝑁))〉}〉) = 𝑉) |
| 26 | eupth2.x | . . . . 5 ⊢ 𝑋 = 〈𝑉, (𝐼 ↾ (𝐹 “ (0..^(𝑁 + 1))))〉 | |
| 27 | 26 | fveq2i 6830 | . . . 4 ⊢ (Vtx‘𝑋) = (Vtx‘〈𝑉, (𝐼 ↾ (𝐹 “ (0..^(𝑁 + 1))))〉) |
| 28 | 18 | resex 5981 | . . . . 5 ⊢ (𝐼 ↾ (𝐹 “ (0..^(𝑁 + 1)))) ∈ V |
| 29 | 17, 28 | opvtxfvi 29096 | . . . 4 ⊢ (Vtx‘〈𝑉, (𝐼 ↾ (𝐹 “ (0..^(𝑁 + 1))))〉) = 𝑉 |
| 30 | 27, 29 | eqtri 2762 | . . 3 ⊢ (Vtx‘𝑋) = 𝑉 |
| 31 | 30 | a1i 11 | . 2 ⊢ (𝜑 → (Vtx‘𝑋) = 𝑉) |
| 32 | 15 | fveq2i 6830 | . . . 4 ⊢ (iEdg‘𝐻) = (iEdg‘〈𝑉, (𝐼 ↾ (𝐹 “ (0..^𝑁)))〉) |
| 33 | 17, 19 | opiedgfvi 29097 | . . . 4 ⊢ (iEdg‘〈𝑉, (𝐼 ↾ (𝐹 “ (0..^𝑁)))〉) = (𝐼 ↾ (𝐹 “ (0..^𝑁))) |
| 34 | 32, 33 | eqtri 2762 | . . 3 ⊢ (iEdg‘𝐻) = (𝐼 ↾ (𝐹 “ (0..^𝑁))) |
| 35 | 34 | a1i 11 | . 2 ⊢ (𝜑 → (iEdg‘𝐻) = (𝐼 ↾ (𝐹 “ (0..^𝑁)))) |
| 36 | 17, 23 | opiedgfvi 29097 | . . 3 ⊢ (iEdg‘〈𝑉, {〈(𝐹‘𝑁), (𝐼‘(𝐹‘𝑁))〉}〉) = {〈(𝐹‘𝑁), (𝐼‘(𝐹‘𝑁))〉} |
| 37 | 36 | a1i 11 | . 2 ⊢ (𝜑 → (iEdg‘〈𝑉, {〈(𝐹‘𝑁), (𝐼‘(𝐹‘𝑁))〉}〉) = {〈(𝐹‘𝑁), (𝐼‘(𝐹‘𝑁))〉}) |
| 38 | 26 | fveq2i 6830 | . . . 4 ⊢ (iEdg‘𝑋) = (iEdg‘〈𝑉, (𝐼 ↾ (𝐹 “ (0..^(𝑁 + 1))))〉) |
| 39 | 17, 28 | opiedgfvi 29097 | . . . 4 ⊢ (iEdg‘〈𝑉, (𝐼 ↾ (𝐹 “ (0..^(𝑁 + 1))))〉) = (𝐼 ↾ (𝐹 “ (0..^(𝑁 + 1)))) |
| 40 | 38, 39 | eqtri 2762 | . . 3 ⊢ (iEdg‘𝑋) = (𝐼 ↾ (𝐹 “ (0..^(𝑁 + 1)))) |
| 41 | 4 | nn0zd 12540 | . . . . . 6 ⊢ (𝜑 → 𝑁 ∈ ℤ) |
| 42 | fzval3 13680 | . . . . . . 7 ⊢ (𝑁 ∈ ℤ → (0...𝑁) = (0..^(𝑁 + 1))) | |
| 43 | 42 | eqcomd 2745 | . . . . . 6 ⊢ (𝑁 ∈ ℤ → (0..^(𝑁 + 1)) = (0...𝑁)) |
| 44 | 41, 43 | syl 17 | . . . . 5 ⊢ (𝜑 → (0..^(𝑁 + 1)) = (0...𝑁)) |
| 45 | 44 | imaeq2d 6012 | . . . 4 ⊢ (𝜑 → (𝐹 “ (0..^(𝑁 + 1))) = (𝐹 “ (0...𝑁))) |
| 46 | 45 | reseq2d 5931 | . . 3 ⊢ (𝜑 → (𝐼 ↾ (𝐹 “ (0..^(𝑁 + 1)))) = (𝐼 ↾ (𝐹 “ (0...𝑁)))) |
| 47 | 40, 46 | eqtrid 2786 | . 2 ⊢ (𝜑 → (iEdg‘𝑋) = (𝐼 ↾ (𝐹 “ (0...𝑁)))) |
| 48 | eupth2.o | . 2 ⊢ (𝜑 → {𝑥 ∈ 𝑉 ∣ ¬ 2 ∥ ((VtxDeg‘𝐻)‘𝑥)} = if((𝑃‘0) = (𝑃‘𝑁), ∅, {(𝑃‘0), (𝑃‘𝑁)})) | |
| 49 | 2fveq3 6832 | . . . 4 ⊢ (𝑘 = 𝑁 → (𝐼‘(𝐹‘𝑘)) = (𝐼‘(𝐹‘𝑁))) | |
| 50 | fveq2 6827 | . . . . 5 ⊢ (𝑘 = 𝑁 → (𝑃‘𝑘) = (𝑃‘𝑁)) | |
| 51 | fvoveq1 7379 | . . . . 5 ⊢ (𝑘 = 𝑁 → (𝑃‘(𝑘 + 1)) = (𝑃‘(𝑁 + 1))) | |
| 52 | 50, 51 | preq12d 4673 | . . . 4 ⊢ (𝑘 = 𝑁 → {(𝑃‘𝑘), (𝑃‘(𝑘 + 1))} = {(𝑃‘𝑁), (𝑃‘(𝑁 + 1))}) |
| 53 | 49, 52 | eqeq12d 2755 | . . 3 ⊢ (𝑘 = 𝑁 → ((𝐼‘(𝐹‘𝑘)) = {(𝑃‘𝑘), (𝑃‘(𝑘 + 1))} ↔ (𝐼‘(𝐹‘𝑁)) = {(𝑃‘𝑁), (𝑃‘(𝑁 + 1))})) |
| 54 | eupth2.g | . . . 4 ⊢ (𝜑 → 𝐺 ∈ UPGraph) | |
| 55 | 5, 6 | syl 17 | . . . 4 ⊢ (𝜑 → 𝐹(Walks‘𝐺)𝑃) |
| 56 | 2 | upgrwlkedg 29728 | . . . 4 ⊢ ((𝐺 ∈ UPGraph ∧ 𝐹(Walks‘𝐺)𝑃) → ∀𝑘 ∈ (0..^(♯‘𝐹))(𝐼‘(𝐹‘𝑘)) = {(𝑃‘𝑘), (𝑃‘(𝑘 + 1))}) |
| 57 | 54, 55, 56 | syl2anc 590 | . . 3 ⊢ (𝜑 → ∀𝑘 ∈ (0..^(♯‘𝐹))(𝐼‘(𝐹‘𝑘)) = {(𝑃‘𝑘), (𝑃‘(𝑘 + 1))}) |
| 58 | 53, 57, 11 | rspcdva 3561 | . 2 ⊢ (𝜑 → (𝐼‘(𝐹‘𝑁)) = {(𝑃‘𝑁), (𝑃‘(𝑁 + 1))}) |
| 59 | 1, 2, 3, 11, 12, 14, 22, 25, 31, 35, 37, 47, 48, 58 | eupth2lem3lem7 30322 | 1 ⊢ (𝜑 → (¬ 2 ∥ ((VtxDeg‘𝑋)‘𝑈) ↔ 𝑈 ∈ if((𝑃‘0) = (𝑃‘(𝑁 + 1)), ∅, {(𝑃‘0), (𝑃‘(𝑁 + 1))}))) |
| Colors of variables: wff setvar class |
| Syntax hints: ¬ wn 3 → wi 4 ↔ wb 207 = wceq 1547 ∈ wcel 2119 ∀wral 3053 {crab 3391 ∅c0 4261 ifcif 4454 {csn 4555 {cpr 4557 〈cop 4561 class class class wbr 5072 ↾ cres 5620 “ cima 5621 Fun wfun 6479 ‘cfv 6485 (class class class)co 7356 0cc0 11029 1c1 11030 + caddc 11032 ≤ cle 11171 2c2 12227 ℕ0cn0 12428 ℤcz 12515 ...cfz 13452 ..^cfzo 13599 ♯chash 14283 ∥ cdvds 16212 Vtxcvtx 29083 iEdgciedg 29084 UPGraphcupgr 29167 VtxDegcvtxdg 29552 Walkscwlks 29683 Trailsctrls 29775 EulerPathsceupth 30285 |
| This theorem was proved from axioms: ax-mp 5 ax-1 6 ax-2 7 ax-3 8 ax-gen 1802 ax-4 1816 ax-5 1917 ax-6 1974 ax-7 2015 ax-8 2121 ax-9 2129 ax-10 2152 ax-11 2168 ax-12 2189 ax-ext 2711 ax-rep 5199 ax-sep 5218 ax-nul 5228 ax-pow 5294 ax-pr 5362 ax-un 7678 ax-cnex 11085 ax-resscn 11086 ax-1cn 11087 ax-icn 11088 ax-addcl 11089 ax-addrcl 11090 ax-mulcl 11091 ax-mulrcl 11092 ax-mulcom 11093 ax-addass 11094 ax-mulass 11095 ax-distr 11096 ax-i2m1 11097 ax-1ne0 11098 ax-1rid 11099 ax-rnegex 11100 ax-rrecex 11101 ax-cnre 11102 ax-pre-lttri 11103 ax-pre-lttrn 11104 ax-pre-ltadd 11105 ax-pre-mulgt0 11106 ax-pre-sup 11107 |
| This theorem depends on definitions: df-bi 208 df-an 397 df-or 854 df-ifp 1069 df-3or 1093 df-3an 1094 df-tru 1550 df-fal 1560 df-ex 1787 df-nf 1791 df-sb 2074 df-mo 2543 df-eu 2573 df-clab 2718 df-cleq 2731 df-clel 2814 df-nfc 2888 df-ne 2935 df-nel 3039 df-ral 3054 df-rex 3064 df-rmo 3344 df-reu 3345 df-rab 3392 df-v 3433 df-sbc 3724 df-csb 3832 df-dif 3886 df-un 3888 df-in 3890 df-ss 3900 df-pss 3903 df-nul 4262 df-if 4455 df-pw 4531 df-sn 4556 df-pr 4558 df-op 4562 df-uni 4839 df-int 4878 df-iun 4923 df-br 5073 df-opab 5135 df-mpt 5154 df-tr 5180 df-id 5513 df-eprel 5518 df-po 5526 df-so 5527 df-fr 5571 df-we 5573 df-xp 5624 df-rel 5625 df-cnv 5626 df-co 5627 df-dm 5628 df-rn 5629 df-res 5630 df-ima 5631 df-pred 6252 df-ord 6313 df-on 6314 df-lim 6315 df-suc 6316 df-iota 6441 df-fun 6487 df-fn 6488 df-f 6489 df-f1 6490 df-fo 6491 df-f1o 6492 df-fv 6493 df-riota 7313 df-ov 7359 df-oprab 7360 df-mpo 7361 df-om 7807 df-1st 7931 df-2nd 7932 df-frecs 8221 df-wrecs 8252 df-recs 8301 df-rdg 8339 df-1o 8395 df-2o 8396 df-oadd 8399 df-er 8633 df-map 8765 df-pm 8766 df-en 8884 df-dom 8885 df-sdom 8886 df-fin 8887 df-sup 9345 df-inf 9346 df-dju 9816 df-card 9854 df-pnf 11172 df-mnf 11173 df-xr 11174 df-ltxr 11175 df-le 11176 df-sub 11370 df-neg 11371 df-div 11799 df-nn 12166 df-2 12235 df-3 12236 df-n0 12429 df-xnn0 12502 df-z 12516 df-uz 12780 df-rp 12934 df-xadd 13055 df-fz 13453 df-fzo 13600 df-seq 13955 df-exp 14015 df-hash 14284 df-word 14467 df-cj 15052 df-re 15053 df-im 15054 df-sqrt 15188 df-abs 15189 df-dvds 16213 df-vtx 29085 df-iedg 29086 df-edg 29135 df-uhgr 29145 df-ushgr 29146 df-upgr 29169 df-uspgr 29237 df-vtxdg 29553 df-wlks 29686 df-trls 29777 df-eupth 30286 |
| This theorem is referenced by: eupth2lems 30326 |
| Copyright terms: Public domain | W3C validator |