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

Theorem subfzo0 13437
Description: The difference between two elements in a half-open range of nonnegative integers is greater than the negation of the upper bound and less than the upper bound of the range. (Contributed by AV, 20-Mar-2021.)
Assertion
Ref Expression
subfzo0 ((𝐼 ∈ (0..^𝑁) ∧ 𝐽 ∈ (0..^𝑁)) → (-𝑁 < (𝐼𝐽) ∧ (𝐼𝐽) < 𝑁))

Proof of Theorem subfzo0
StepHypRef Expression
1 elfzo0 13356 . . 3 (𝐼 ∈ (0..^𝑁) ↔ (𝐼 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐼 < 𝑁))
2 elfzo0 13356 . . . . 5 (𝐽 ∈ (0..^𝑁) ↔ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁))
3 nn0re 12172 . . . . . . . . . . . 12 (𝐼 ∈ ℕ0𝐼 ∈ ℝ)
43adantr 480 . . . . . . . . . . 11 ((𝐼 ∈ ℕ0𝐼 < 𝑁) → 𝐼 ∈ ℝ)
5 nnre 11910 . . . . . . . . . . . . . 14 (𝑁 ∈ ℕ → 𝑁 ∈ ℝ)
6 nn0re 12172 . . . . . . . . . . . . . 14 (𝐽 ∈ ℕ0𝐽 ∈ ℝ)
7 resubcl 11215 . . . . . . . . . . . . . 14 ((𝑁 ∈ ℝ ∧ 𝐽 ∈ ℝ) → (𝑁𝐽) ∈ ℝ)
85, 6, 7syl2an 595 . . . . . . . . . . . . 13 ((𝑁 ∈ ℕ ∧ 𝐽 ∈ ℕ0) → (𝑁𝐽) ∈ ℝ)
98ancoms 458 . . . . . . . . . . . 12 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ) → (𝑁𝐽) ∈ ℝ)
1093adant3 1130 . . . . . . . . . . 11 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → (𝑁𝐽) ∈ ℝ)
114, 10anim12i 612 . . . . . . . . . 10 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (𝐼 ∈ ℝ ∧ (𝑁𝐽) ∈ ℝ))
12 nn0ge0 12188 . . . . . . . . . . . 12 (𝐼 ∈ ℕ0 → 0 ≤ 𝐼)
1312adantr 480 . . . . . . . . . . 11 ((𝐼 ∈ ℕ0𝐼 < 𝑁) → 0 ≤ 𝐼)
14 posdif 11398 . . . . . . . . . . . . 13 ((𝐽 ∈ ℝ ∧ 𝑁 ∈ ℝ) → (𝐽 < 𝑁 ↔ 0 < (𝑁𝐽)))
156, 5, 14syl2an 595 . . . . . . . . . . . 12 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ) → (𝐽 < 𝑁 ↔ 0 < (𝑁𝐽)))
1615biimp3a 1467 . . . . . . . . . . 11 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → 0 < (𝑁𝐽))
1713, 16anim12i 612 . . . . . . . . . 10 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (0 ≤ 𝐼 ∧ 0 < (𝑁𝐽)))
18 addgegt0 11392 . . . . . . . . . 10 (((𝐼 ∈ ℝ ∧ (𝑁𝐽) ∈ ℝ) ∧ (0 ≤ 𝐼 ∧ 0 < (𝑁𝐽))) → 0 < (𝐼 + (𝑁𝐽)))
1911, 17, 18syl2anc 583 . . . . . . . . 9 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 0 < (𝐼 + (𝑁𝐽)))
20 nn0cn 12173 . . . . . . . . . . . 12 (𝐼 ∈ ℕ0𝐼 ∈ ℂ)
2120adantr 480 . . . . . . . . . . 11 ((𝐼 ∈ ℕ0𝐼 < 𝑁) → 𝐼 ∈ ℂ)
2221adantr 480 . . . . . . . . . 10 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 𝐼 ∈ ℂ)
23 nn0cn 12173 . . . . . . . . . . . 12 (𝐽 ∈ ℕ0𝐽 ∈ ℂ)
24233ad2ant1 1131 . . . . . . . . . . 11 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → 𝐽 ∈ ℂ)
2524adantl 481 . . . . . . . . . 10 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 𝐽 ∈ ℂ)
26 nncn 11911 . . . . . . . . . . . 12 (𝑁 ∈ ℕ → 𝑁 ∈ ℂ)
27263ad2ant2 1132 . . . . . . . . . . 11 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → 𝑁 ∈ ℂ)
2827adantl 481 . . . . . . . . . 10 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 𝑁 ∈ ℂ)
2922, 25, 28subadd23d 11284 . . . . . . . . 9 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → ((𝐼𝐽) + 𝑁) = (𝐼 + (𝑁𝐽)))
3019, 29breqtrrd 5098 . . . . . . . 8 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 0 < ((𝐼𝐽) + 𝑁))
3163ad2ant1 1131 . . . . . . . . . 10 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → 𝐽 ∈ ℝ)
32 resubcl 11215 . . . . . . . . . 10 ((𝐼 ∈ ℝ ∧ 𝐽 ∈ ℝ) → (𝐼𝐽) ∈ ℝ)
334, 31, 32syl2an 595 . . . . . . . . 9 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (𝐼𝐽) ∈ ℝ)
3453ad2ant2 1132 . . . . . . . . . 10 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → 𝑁 ∈ ℝ)
3534adantl 481 . . . . . . . . 9 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 𝑁 ∈ ℝ)
3633, 35possumd 11530 . . . . . . . 8 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (0 < ((𝐼𝐽) + 𝑁) ↔ -𝑁 < (𝐼𝐽)))
3730, 36mpbid 231 . . . . . . 7 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → -𝑁 < (𝐼𝐽))
383adantr 480 . . . . . . . . . . . 12 ((𝐼 ∈ ℕ0 ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 𝐼 ∈ ℝ)
3934adantl 481 . . . . . . . . . . . 12 ((𝐼 ∈ ℕ0 ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 𝑁 ∈ ℝ)
40 readdcl 10885 . . . . . . . . . . . . . . 15 ((𝐽 ∈ ℝ ∧ 𝑁 ∈ ℝ) → (𝐽 + 𝑁) ∈ ℝ)
416, 5, 40syl2an 595 . . . . . . . . . . . . . 14 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ) → (𝐽 + 𝑁) ∈ ℝ)
42413adant3 1130 . . . . . . . . . . . . 13 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → (𝐽 + 𝑁) ∈ ℝ)
4342adantl 481 . . . . . . . . . . . 12 ((𝐼 ∈ ℕ0 ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (𝐽 + 𝑁) ∈ ℝ)
4438, 39, 433jca 1126 . . . . . . . . . . 11 ((𝐼 ∈ ℕ0 ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (𝐼 ∈ ℝ ∧ 𝑁 ∈ ℝ ∧ (𝐽 + 𝑁) ∈ ℝ))
45 nn0ge0 12188 . . . . . . . . . . . . . 14 (𝐽 ∈ ℕ0 → 0 ≤ 𝐽)
46453ad2ant1 1131 . . . . . . . . . . . . 13 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → 0 ≤ 𝐽)
4746adantl 481 . . . . . . . . . . . 12 ((𝐼 ∈ ℕ0 ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 0 ≤ 𝐽)
485, 6anim12i 612 . . . . . . . . . . . . . . . 16 ((𝑁 ∈ ℕ ∧ 𝐽 ∈ ℕ0) → (𝑁 ∈ ℝ ∧ 𝐽 ∈ ℝ))
4948ancoms 458 . . . . . . . . . . . . . . 15 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ) → (𝑁 ∈ ℝ ∧ 𝐽 ∈ ℝ))
50493adant3 1130 . . . . . . . . . . . . . 14 ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → (𝑁 ∈ ℝ ∧ 𝐽 ∈ ℝ))
5150adantl 481 . . . . . . . . . . . . 13 ((𝐼 ∈ ℕ0 ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (𝑁 ∈ ℝ ∧ 𝐽 ∈ ℝ))
52 addge02 11416 . . . . . . . . . . . . 13 ((𝑁 ∈ ℝ ∧ 𝐽 ∈ ℝ) → (0 ≤ 𝐽𝑁 ≤ (𝐽 + 𝑁)))
5351, 52syl 17 . . . . . . . . . . . 12 ((𝐼 ∈ ℕ0 ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (0 ≤ 𝐽𝑁 ≤ (𝐽 + 𝑁)))
5447, 53mpbid 231 . . . . . . . . . . 11 ((𝐼 ∈ ℕ0 ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 𝑁 ≤ (𝐽 + 𝑁))
5544, 54lelttrdi 11067 . . . . . . . . . 10 ((𝐼 ∈ ℕ0 ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (𝐼 < 𝑁𝐼 < (𝐽 + 𝑁)))
5655impancom 451 . . . . . . . . 9 ((𝐼 ∈ ℕ0𝐼 < 𝑁) → ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → 𝐼 < (𝐽 + 𝑁)))
5756imp 406 . . . . . . . 8 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 𝐼 < (𝐽 + 𝑁))
584adantr 480 . . . . . . . . 9 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 𝐼 ∈ ℝ)
5931adantl 481 . . . . . . . . 9 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → 𝐽 ∈ ℝ)
6058, 59, 35ltsubadd2d 11503 . . . . . . . 8 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → ((𝐼𝐽) < 𝑁𝐼 < (𝐽 + 𝑁)))
6157, 60mpbird 256 . . . . . . 7 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (𝐼𝐽) < 𝑁)
6237, 61jca 511 . . . . . 6 (((𝐼 ∈ ℕ0𝐼 < 𝑁) ∧ (𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁)) → (-𝑁 < (𝐼𝐽) ∧ (𝐼𝐽) < 𝑁))
6362ex 412 . . . . 5 ((𝐼 ∈ ℕ0𝐼 < 𝑁) → ((𝐽 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐽 < 𝑁) → (-𝑁 < (𝐼𝐽) ∧ (𝐼𝐽) < 𝑁)))
642, 63syl5bi 241 . . . 4 ((𝐼 ∈ ℕ0𝐼 < 𝑁) → (𝐽 ∈ (0..^𝑁) → (-𝑁 < (𝐼𝐽) ∧ (𝐼𝐽) < 𝑁)))
65643adant2 1129 . . 3 ((𝐼 ∈ ℕ0𝑁 ∈ ℕ ∧ 𝐼 < 𝑁) → (𝐽 ∈ (0..^𝑁) → (-𝑁 < (𝐼𝐽) ∧ (𝐼𝐽) < 𝑁)))
661, 65sylbi 216 . 2 (𝐼 ∈ (0..^𝑁) → (𝐽 ∈ (0..^𝑁) → (-𝑁 < (𝐼𝐽) ∧ (𝐼𝐽) < 𝑁)))
6766imp 406 1 ((𝐼 ∈ (0..^𝑁) ∧ 𝐽 ∈ (0..^𝑁)) → (-𝑁 < (𝐼𝐽) ∧ (𝐼𝐽) < 𝑁))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 205  wa 395  w3a 1085  wcel 2108   class class class wbr 5070  (class class class)co 7255  cc 10800  cr 10801  0cc0 10802   + caddc 10805   < clt 10940  cle 10941  cmin 11135  -cneg 11136  cn 11903  0cn0 12163  ..^cfzo 13311
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1799  ax-4 1813  ax-5 1914  ax-6 1972  ax-7 2012  ax-8 2110  ax-9 2118  ax-10 2139  ax-11 2156  ax-12 2173  ax-ext 2709  ax-sep 5218  ax-nul 5225  ax-pow 5283  ax-pr 5347  ax-un 7566  ax-cnex 10858  ax-resscn 10859  ax-1cn 10860  ax-icn 10861  ax-addcl 10862  ax-addrcl 10863  ax-mulcl 10864  ax-mulrcl 10865  ax-mulcom 10866  ax-addass 10867  ax-mulass 10868  ax-distr 10869  ax-i2m1 10870  ax-1ne0 10871  ax-1rid 10872  ax-rnegex 10873  ax-rrecex 10874  ax-cnre 10875  ax-pre-lttri 10876  ax-pre-lttrn 10877  ax-pre-ltadd 10878  ax-pre-mulgt0 10879
This theorem depends on definitions:  df-bi 206  df-an 396  df-or 844  df-3or 1086  df-3an 1087  df-tru 1542  df-fal 1552  df-ex 1784  df-nf 1788  df-sb 2069  df-mo 2540  df-eu 2569  df-clab 2716  df-cleq 2730  df-clel 2817  df-nfc 2888  df-ne 2943  df-nel 3049  df-ral 3068  df-rex 3069  df-reu 3070  df-rab 3072  df-v 3424  df-sbc 3712  df-csb 3829  df-dif 3886  df-un 3888  df-in 3890  df-ss 3900  df-pss 3902  df-nul 4254  df-if 4457  df-pw 4532  df-sn 4559  df-pr 4561  df-tp 4563  df-op 4565  df-uni 4837  df-iun 4923  df-br 5071  df-opab 5133  df-mpt 5154  df-tr 5188  df-id 5480  df-eprel 5486  df-po 5494  df-so 5495  df-fr 5535  df-we 5537  df-xp 5586  df-rel 5587  df-cnv 5588  df-co 5589  df-dm 5590  df-rn 5591  df-res 5592  df-ima 5593  df-pred 6191  df-ord 6254  df-on 6255  df-lim 6256  df-suc 6257  df-iota 6376  df-fun 6420  df-fn 6421  df-f 6422  df-f1 6423  df-fo 6424  df-f1o 6425  df-fv 6426  df-riota 7212  df-ov 7258  df-oprab 7259  df-mpo 7260  df-om 7688  df-1st 7804  df-2nd 7805  df-frecs 8068  df-wrecs 8099  df-recs 8173  df-rdg 8212  df-er 8456  df-en 8692  df-dom 8693  df-sdom 8694  df-pnf 10942  df-mnf 10943  df-xr 10944  df-ltxr 10945  df-le 10946  df-sub 11137  df-neg 11138  df-nn 11904  df-n0 12164  df-z 12250  df-uz 12512  df-fz 13169  df-fzo 13312
This theorem is referenced by:  addmodlteq  13594
  Copyright terms: Public domain W3C validator