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

Theorem eleclclwwlknlem2 27832
Description: Lemma 2 for eleclclwwlkn 27847. (Contributed by Alexander van der Vekens, 11-May-2018.) (Revised by AV, 30-Apr-2021.)
Hypothesis
Ref Expression
erclwwlkn1.w 𝑊 = (𝑁 ClWWalksN 𝐺)
Assertion
Ref Expression
eleclclwwlknlem2 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚) ↔ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)))
Distinct variable groups:   𝑚,𝑛,𝐺   𝑚,𝑁,𝑛   𝑚,𝑋,𝑛   𝑚,𝑌,𝑛   𝑘,𝑚,𝑛   𝑥,𝑚,𝑛
Allowed substitution hints:   𝐺(𝑥,𝑘)   𝑁(𝑥,𝑘)   𝑊(𝑥,𝑘,𝑚,𝑛)   𝑋(𝑥,𝑘)   𝑌(𝑥,𝑘)

Proof of Theorem eleclclwwlknlem2
StepHypRef Expression
1 simpl 485 . . . . 5 ((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) → 𝑘 ∈ (0...𝑁))
21anim1i 616 . . . 4 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑘 ∈ (0...𝑁) ∧ (𝑋𝑊𝑥𝑊)))
32adantr 483 . . 3 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)) → (𝑘 ∈ (0...𝑁) ∧ (𝑋𝑊𝑥𝑊)))
4 simpr 487 . . . . 5 ((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) → 𝑋 = (𝑥 cyclShift 𝑘))
54adantr 483 . . . 4 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → 𝑋 = (𝑥 cyclShift 𝑘))
65anim1i 616 . . 3 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)) → (𝑋 = (𝑥 cyclShift 𝑘) ∧ ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)))
7 erclwwlkn1.w . . . 4 𝑊 = (𝑁 ClWWalksN 𝐺)
87eleclclwwlknlem1 27831 . . 3 ((𝑘 ∈ (0...𝑁) ∧ (𝑋𝑊𝑥𝑊)) → ((𝑋 = (𝑥 cyclShift 𝑘) ∧ ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)) → ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)))
93, 6, 8sylc 65 . 2 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)) → ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛))
10 eqid 2819 . . . . . . . . . . . 12 (Vtx‘𝐺) = (Vtx‘𝐺)
1110clwwlknbp 27805 . . . . . . . . . . 11 (𝑥 ∈ (𝑁 ClWWalksN 𝐺) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁))
1211, 7eleq2s 2929 . . . . . . . . . 10 (𝑥𝑊 → (𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁))
13 fznn0sub2 13006 . . . . . . . . . . . 12 (𝑘 ∈ (0...𝑁) → (𝑁𝑘) ∈ (0...𝑁))
14 oveq1 7155 . . . . . . . . . . . . 13 ((♯‘𝑥) = 𝑁 → ((♯‘𝑥) − 𝑘) = (𝑁𝑘))
1514eleq1d 2895 . . . . . . . . . . . 12 ((♯‘𝑥) = 𝑁 → (((♯‘𝑥) − 𝑘) ∈ (0...𝑁) ↔ (𝑁𝑘) ∈ (0...𝑁)))
1613, 15syl5ibr 248 . . . . . . . . . . 11 ((♯‘𝑥) = 𝑁 → (𝑘 ∈ (0...𝑁) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
1716adantl 484 . . . . . . . . . 10 ((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) → (𝑘 ∈ (0...𝑁) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
1812, 17syl 17 . . . . . . . . 9 (𝑥𝑊 → (𝑘 ∈ (0...𝑁) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
1918adantl 484 . . . . . . . 8 ((𝑋𝑊𝑥𝑊) → (𝑘 ∈ (0...𝑁) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
2019com12 32 . . . . . . 7 (𝑘 ∈ (0...𝑁) → ((𝑋𝑊𝑥𝑊) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
2120adantr 483 . . . . . 6 ((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) → ((𝑋𝑊𝑥𝑊) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁)))
2221imp 409 . . . . 5 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁))
2322adantr 483 . . . 4 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → ((♯‘𝑥) − 𝑘) ∈ (0...𝑁))
24 simpr 487 . . . . . 6 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑋𝑊𝑥𝑊))
2524ancomd 464 . . . . 5 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑥𝑊𝑋𝑊))
2625adantr 483 . . . 4 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → (𝑥𝑊𝑋𝑊))
2723, 26jca 514 . . 3 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → (((♯‘𝑥) − 𝑘) ∈ (0...𝑁) ∧ (𝑥𝑊𝑋𝑊)))
28 simpll 765 . . . . . . . . . . . . 13 (((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) ∧ 𝑘 ∈ (0...𝑁)) → 𝑥 ∈ Word (Vtx‘𝐺))
29 oveq2 7156 . . . . . . . . . . . . . . . . 17 (𝑁 = (♯‘𝑥) → (0...𝑁) = (0...(♯‘𝑥)))
3029eleq2d 2896 . . . . . . . . . . . . . . . 16 (𝑁 = (♯‘𝑥) → (𝑘 ∈ (0...𝑁) ↔ 𝑘 ∈ (0...(♯‘𝑥))))
3130eqcoms 2827 . . . . . . . . . . . . . . 15 ((♯‘𝑥) = 𝑁 → (𝑘 ∈ (0...𝑁) ↔ 𝑘 ∈ (0...(♯‘𝑥))))
3231adantl 484 . . . . . . . . . . . . . 14 ((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) → (𝑘 ∈ (0...𝑁) ↔ 𝑘 ∈ (0...(♯‘𝑥))))
3332biimpa 479 . . . . . . . . . . . . 13 (((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) ∧ 𝑘 ∈ (0...𝑁)) → 𝑘 ∈ (0...(♯‘𝑥)))
3428, 33jca 514 . . . . . . . . . . . 12 (((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) ∧ 𝑘 ∈ (0...𝑁)) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥))))
3534ex 415 . . . . . . . . . . 11 ((𝑥 ∈ Word (Vtx‘𝐺) ∧ (♯‘𝑥) = 𝑁) → (𝑘 ∈ (0...𝑁) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥)))))
3612, 35syl 17 . . . . . . . . . 10 (𝑥𝑊 → (𝑘 ∈ (0...𝑁) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥)))))
3736adantl 484 . . . . . . . . 9 ((𝑋𝑊𝑥𝑊) → (𝑘 ∈ (0...𝑁) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥)))))
3837com12 32 . . . . . . . 8 (𝑘 ∈ (0...𝑁) → ((𝑋𝑊𝑥𝑊) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥)))))
3938adantr 483 . . . . . . 7 ((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) → ((𝑋𝑊𝑥𝑊) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥)))))
4039imp 409 . . . . . 6 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥))))
414eqcomd 2825 . . . . . . 7 ((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) → (𝑥 cyclShift 𝑘) = 𝑋)
4241adantr 483 . . . . . 6 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑥 cyclShift 𝑘) = 𝑋)
43 oveq1 7155 . . . . . . . 8 (𝑋 = (𝑥 cyclShift 𝑘) → (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) = ((𝑥 cyclShift 𝑘) cyclShift ((♯‘𝑥) − 𝑘)))
4443eqcoms 2827 . . . . . . 7 ((𝑥 cyclShift 𝑘) = 𝑋 → (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) = ((𝑥 cyclShift 𝑘) cyclShift ((♯‘𝑥) − 𝑘)))
45 elfzelz 12900 . . . . . . . 8 (𝑘 ∈ (0...(♯‘𝑥)) → 𝑘 ∈ ℤ)
46 2cshwid 14168 . . . . . . . 8 ((𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ ℤ) → ((𝑥 cyclShift 𝑘) cyclShift ((♯‘𝑥) − 𝑘)) = 𝑥)
4745, 46sylan2 594 . . . . . . 7 ((𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥))) → ((𝑥 cyclShift 𝑘) cyclShift ((♯‘𝑥) − 𝑘)) = 𝑥)
4844, 47sylan9eqr 2876 . . . . . 6 (((𝑥 ∈ Word (Vtx‘𝐺) ∧ 𝑘 ∈ (0...(♯‘𝑥))) ∧ (𝑥 cyclShift 𝑘) = 𝑋) → (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) = 𝑥)
4940, 42, 48syl2anc 586 . . . . 5 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) = 𝑥)
5049eqcomd 2825 . . . 4 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → 𝑥 = (𝑋 cyclShift ((♯‘𝑥) − 𝑘)))
5150anim1i 616 . . 3 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → (𝑥 = (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)))
527eleclclwwlknlem1 27831 . . 3 ((((♯‘𝑥) − 𝑘) ∈ (0...𝑁) ∧ (𝑥𝑊𝑋𝑊)) → ((𝑥 = (𝑋 cyclShift ((♯‘𝑥) − 𝑘)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚)))
5327, 51, 52sylc 65 . 2 ((((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) ∧ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)) → ∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚))
549, 53impbida 799 1 (((𝑘 ∈ (0...𝑁) ∧ 𝑋 = (𝑥 cyclShift 𝑘)) ∧ (𝑋𝑊𝑥𝑊)) → (∃𝑚 ∈ (0...𝑁)𝑌 = (𝑥 cyclShift 𝑚) ↔ ∃𝑛 ∈ (0...𝑁)𝑌 = (𝑋 cyclShift 𝑛)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 208  wa 398   = wceq 1531  wcel 2108  wrex 3137  cfv 6348  (class class class)co 7148  0cc0 10529  cmin 10862  cz 11973  ...cfz 12884  chash 13682  Word cword 13853   cyclShift ccsh 14142  Vtxcvtx 26773   ClWWalksN cclwwlkn 27794
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1790  ax-4 1804  ax-5 1905  ax-6 1964  ax-7 2009  ax-8 2110  ax-9 2118  ax-10 2139  ax-11 2154  ax-12 2170  ax-ext 2791  ax-rep 5181  ax-sep 5194  ax-nul 5201  ax-pow 5257  ax-pr 5320  ax-un 7453  ax-cnex 10585  ax-resscn 10586  ax-1cn 10587  ax-icn 10588  ax-addcl 10589  ax-addrcl 10590  ax-mulcl 10591  ax-mulrcl 10592  ax-mulcom 10593  ax-addass 10594  ax-mulass 10595  ax-distr 10596  ax-i2m1 10597  ax-1ne0 10598  ax-1rid 10599  ax-rnegex 10600  ax-rrecex 10601  ax-cnre 10602  ax-pre-lttri 10603  ax-pre-lttrn 10604  ax-pre-ltadd 10605  ax-pre-mulgt0 10606  ax-pre-sup 10607
This theorem depends on definitions:  df-bi 209  df-an 399  df-or 844  df-3or 1083  df-3an 1084  df-tru 1534  df-ex 1775  df-nf 1779  df-sb 2064  df-mo 2616  df-eu 2648  df-clab 2798  df-cleq 2812  df-clel 2891  df-nfc 2961  df-ne 3015  df-nel 3122  df-ral 3141  df-rex 3142  df-reu 3143  df-rmo 3144  df-rab 3145  df-v 3495  df-sbc 3771  df-csb 3882  df-dif 3937  df-un 3939  df-in 3941  df-ss 3950  df-pss 3952  df-nul 4290  df-if 4466  df-pw 4539  df-sn 4560  df-pr 4562  df-tp 4564  df-op 4566  df-uni 4831  df-int 4868  df-iun 4912  df-br 5058  df-opab 5120  df-mpt 5138  df-tr 5164  df-id 5453  df-eprel 5458  df-po 5467  df-so 5468  df-fr 5507  df-we 5509  df-xp 5554  df-rel 5555  df-cnv 5556  df-co 5557  df-dm 5558  df-rn 5559  df-res 5560  df-ima 5561  df-pred 6141  df-ord 6187  df-on 6188  df-lim 6189  df-suc 6190  df-iota 6307  df-fun 6350  df-fn 6351  df-f 6352  df-f1 6353  df-fo 6354  df-f1o 6355  df-fv 6356  df-riota 7106  df-ov 7151  df-oprab 7152  df-mpo 7153  df-om 7573  df-1st 7681  df-2nd 7682  df-wrecs 7939  df-recs 8000  df-rdg 8038  df-1o 8094  df-oadd 8098  df-er 8281  df-map 8400  df-en 8502  df-dom 8503  df-sdom 8504  df-fin 8505  df-sup 8898  df-inf 8899  df-card 9360  df-pnf 10669  df-mnf 10670  df-xr 10671  df-ltxr 10672  df-le 10673  df-sub 10864  df-neg 10865  df-div 11290  df-nn 11631  df-2 11692  df-n0 11890  df-z 11974  df-uz 12236  df-rp 12382  df-fz 12885  df-fzo 13026  df-fl 13154  df-mod 13230  df-hash 13683  df-word 13854  df-concat 13915  df-substr 13995  df-pfx 14025  df-csh 14143  df-clwwlk 27752  df-clwwlkn 27795
This theorem is referenced by:  eleclclwwlkn  27847
  Copyright terms: Public domain W3C validator