Users' Mathboxes Mathbox for Alexander van der Vekens < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  mod2addne Structured version   Visualization version   GIF version

Theorem mod2addne 47526
Description: The sums of a nonnegative integer less than the modulus and two integers whose difference is less than the modulus are not equal modulo the modulus. (Contributed by AV, 15-Nov-2025.)
Hypothesis
Ref Expression
mod2addne.i 𝐼 = (0..^𝑁)
Assertion
Ref Expression
mod2addne ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → ((𝑋 + 𝐴) mod 𝑁) ≠ ((𝑋 + 𝐵) mod 𝑁))

Proof of Theorem mod2addne
StepHypRef Expression
1 simp1 1136 . . . . . 6 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → 𝑁 ∈ ℕ)
2 zsubcl 12524 . . . . . . . 8 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → (𝐴𝐵) ∈ ℤ)
323adant1 1130 . . . . . . 7 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → (𝐴𝐵) ∈ ℤ)
433ad2ant2 1134 . . . . . 6 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → (𝐴𝐵) ∈ ℤ)
5 elfzolt2 13575 . . . . . . 7 ((abs‘(𝐴𝐵)) ∈ (1..^𝑁) → (abs‘(𝐴𝐵)) < 𝑁)
653ad2ant3 1135 . . . . . 6 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → (abs‘(𝐴𝐵)) < 𝑁)
7 modlt0b 47525 . . . . . 6 ((𝑁 ∈ ℕ ∧ (𝐴𝐵) ∈ ℤ ∧ (abs‘(𝐴𝐵)) < 𝑁) → (((𝐴𝐵) mod 𝑁) = 0 ↔ (𝐴𝐵) = 0))
81, 4, 6, 7syl3anc 1373 . . . . 5 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → (((𝐴𝐵) mod 𝑁) = 0 ↔ (𝐴𝐵) = 0))
9 fveq2 6831 . . . . . . . . . . 11 ((𝐴𝐵) = 0 → (abs‘(𝐴𝐵)) = (abs‘0))
109eleq1d 2818 . . . . . . . . . 10 ((𝐴𝐵) = 0 → ((abs‘(𝐴𝐵)) ∈ (1..^𝑁) ↔ (abs‘0) ∈ (1..^𝑁)))
1110adantl 481 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) ∧ (𝐴𝐵) = 0) → ((abs‘(𝐴𝐵)) ∈ (1..^𝑁) ↔ (abs‘0) ∈ (1..^𝑁)))
12 abs0 15199 . . . . . . . . . . . . 13 (abs‘0) = 0
1312eleq1i 2824 . . . . . . . . . . . 12 ((abs‘0) ∈ (1..^𝑁) ↔ 0 ∈ (1..^𝑁))
1413a1i 11 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → ((abs‘0) ∈ (1..^𝑁) ↔ 0 ∈ (1..^𝑁)))
15 elfzo1 13619 . . . . . . . . . . . . 13 (0 ∈ (1..^𝑁) ↔ (0 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 0 < 𝑁))
16 0nnn 12172 . . . . . . . . . . . . . . 15 ¬ 0 ∈ ℕ
1716pm2.21i 119 . . . . . . . . . . . . . 14 (0 ∈ ℕ → ¬ ((𝐴𝐵) mod 𝑁) = 0)
18173ad2ant1 1133 . . . . . . . . . . . . 13 ((0 ∈ ℕ ∧ 𝑁 ∈ ℕ ∧ 0 < 𝑁) → ¬ ((𝐴𝐵) mod 𝑁) = 0)
1915, 18sylbi 217 . . . . . . . . . . . 12 (0 ∈ (1..^𝑁) → ¬ ((𝐴𝐵) mod 𝑁) = 0)
2019a1i 11 . . . . . . . . . . 11 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → (0 ∈ (1..^𝑁) → ¬ ((𝐴𝐵) mod 𝑁) = 0))
2114, 20sylbid 240 . . . . . . . . . 10 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → ((abs‘0) ∈ (1..^𝑁) → ¬ ((𝐴𝐵) mod 𝑁) = 0))
2221adantr 480 . . . . . . . . 9 (((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) ∧ (𝐴𝐵) = 0) → ((abs‘0) ∈ (1..^𝑁) → ¬ ((𝐴𝐵) mod 𝑁) = 0))
2311, 22sylbid 240 . . . . . . . 8 (((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) ∧ (𝐴𝐵) = 0) → ((abs‘(𝐴𝐵)) ∈ (1..^𝑁) → ¬ ((𝐴𝐵) mod 𝑁) = 0))
2423ex 412 . . . . . . 7 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → ((𝐴𝐵) = 0 → ((abs‘(𝐴𝐵)) ∈ (1..^𝑁) → ¬ ((𝐴𝐵) mod 𝑁) = 0)))
2524com23 86 . . . . . 6 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → ((abs‘(𝐴𝐵)) ∈ (1..^𝑁) → ((𝐴𝐵) = 0 → ¬ ((𝐴𝐵) mod 𝑁) = 0)))
26253impia 1117 . . . . 5 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → ((𝐴𝐵) = 0 → ¬ ((𝐴𝐵) mod 𝑁) = 0))
278, 26sylbid 240 . . . 4 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → (((𝐴𝐵) mod 𝑁) = 0 → ¬ ((𝐴𝐵) mod 𝑁) = 0))
2827pm2.01d 190 . . 3 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → ¬ ((𝐴𝐵) mod 𝑁) = 0)
29 simp2 1137 . . . . . . 7 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → 𝐴 ∈ ℤ)
3029adantl 481 . . . . . 6 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → 𝐴 ∈ ℤ)
31 simp3 1138 . . . . . . 7 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → 𝐵 ∈ ℤ)
3231adantl 481 . . . . . 6 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → 𝐵 ∈ ℤ)
33 simpl 482 . . . . . 6 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → 𝑁 ∈ ℕ)
3430, 32, 333jca 1128 . . . . 5 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → (𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝑁 ∈ ℕ))
35343adant3 1132 . . . 4 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → (𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝑁 ∈ ℕ))
36 difmod0 16205 . . . 4 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ ∧ 𝑁 ∈ ℕ) → (((𝐴𝐵) mod 𝑁) = 0 ↔ (𝐴 mod 𝑁) = (𝐵 mod 𝑁)))
3735, 36syl 17 . . 3 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → (((𝐴𝐵) mod 𝑁) = 0 ↔ (𝐴 mod 𝑁) = (𝐵 mod 𝑁)))
3828, 37mtbid 324 . 2 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → ¬ (𝐴 mod 𝑁) = (𝐵 mod 𝑁))
39 elfzoelz 13566 . . . . . . . . . . 11 (𝑋 ∈ (0..^𝑁) → 𝑋 ∈ ℤ)
40 mod2addne.i . . . . . . . . . . 11 𝐼 = (0..^𝑁)
4139, 40eleq2s 2851 . . . . . . . . . 10 (𝑋𝐼𝑋 ∈ ℤ)
42413ad2ant1 1133 . . . . . . . . 9 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → 𝑋 ∈ ℤ)
4342zcnd 12588 . . . . . . . 8 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → 𝑋 ∈ ℂ)
4429zcnd 12588 . . . . . . . 8 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → 𝐴 ∈ ℂ)
4543, 44addcomd 11326 . . . . . . 7 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → (𝑋 + 𝐴) = (𝐴 + 𝑋))
4645oveq1d 7370 . . . . . 6 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → ((𝑋 + 𝐴) mod 𝑁) = ((𝐴 + 𝑋) mod 𝑁))
4731zcnd 12588 . . . . . . . 8 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → 𝐵 ∈ ℂ)
4843, 47addcomd 11326 . . . . . . 7 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → (𝑋 + 𝐵) = (𝐵 + 𝑋))
4948oveq1d 7370 . . . . . 6 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → ((𝑋 + 𝐵) mod 𝑁) = ((𝐵 + 𝑋) mod 𝑁))
5046, 49eqeq12d 2749 . . . . 5 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → (((𝑋 + 𝐴) mod 𝑁) = ((𝑋 + 𝐵) mod 𝑁) ↔ ((𝐴 + 𝑋) mod 𝑁) = ((𝐵 + 𝑋) mod 𝑁)))
51503ad2ant2 1134 . . . 4 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → (((𝑋 + 𝐴) mod 𝑁) = ((𝑋 + 𝐵) mod 𝑁) ↔ ((𝐴 + 𝑋) mod 𝑁) = ((𝐵 + 𝑋) mod 𝑁)))
52 zre 12483 . . . . . . . . . 10 (𝐴 ∈ ℤ → 𝐴 ∈ ℝ)
53 zre 12483 . . . . . . . . . 10 (𝐵 ∈ ℤ → 𝐵 ∈ ℝ)
5452, 53anim12i 613 . . . . . . . . 9 ((𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → (𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ))
55543adant1 1130 . . . . . . . 8 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → (𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ))
5655adantl 481 . . . . . . 7 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → (𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ))
57 nnrp 12908 . . . . . . . 8 (𝑁 ∈ ℕ → 𝑁 ∈ ℝ+)
5841zred 12587 . . . . . . . . 9 (𝑋𝐼𝑋 ∈ ℝ)
59583ad2ant1 1133 . . . . . . . 8 ((𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) → 𝑋 ∈ ℝ)
6057, 59anim12ci 614 . . . . . . 7 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → (𝑋 ∈ ℝ ∧ 𝑁 ∈ ℝ+))
6156, 60jca 511 . . . . . 6 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ)) → ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ (𝑋 ∈ ℝ ∧ 𝑁 ∈ ℝ+)))
62613adant3 1132 . . . . 5 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ (𝑋 ∈ ℝ ∧ 𝑁 ∈ ℝ+)))
63 modaddb 13820 . . . . 5 (((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ (𝑋 ∈ ℝ ∧ 𝑁 ∈ ℝ+)) → ((𝐴 mod 𝑁) = (𝐵 mod 𝑁) ↔ ((𝐴 + 𝑋) mod 𝑁) = ((𝐵 + 𝑋) mod 𝑁)))
6462, 63syl 17 . . . 4 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → ((𝐴 mod 𝑁) = (𝐵 mod 𝑁) ↔ ((𝐴 + 𝑋) mod 𝑁) = ((𝐵 + 𝑋) mod 𝑁)))
6551, 64bitr4d 282 . . 3 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → (((𝑋 + 𝐴) mod 𝑁) = ((𝑋 + 𝐵) mod 𝑁) ↔ (𝐴 mod 𝑁) = (𝐵 mod 𝑁)))
6665necon3abid 2965 . 2 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → (((𝑋 + 𝐴) mod 𝑁) ≠ ((𝑋 + 𝐵) mod 𝑁) ↔ ¬ (𝐴 mod 𝑁) = (𝐵 mod 𝑁)))
6738, 66mpbird 257 1 ((𝑁 ∈ ℕ ∧ (𝑋𝐼𝐴 ∈ ℤ ∧ 𝐵 ∈ ℤ) ∧ (abs‘(𝐴𝐵)) ∈ (1..^𝑁)) → ((𝑋 + 𝐴) mod 𝑁) ≠ ((𝑋 + 𝐵) mod 𝑁))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 206  wa 395  w3a 1086   = wceq 1541  wcel 2113  wne 2929   class class class wbr 5095  cfv 6489  (class class class)co 7355  cr 11016  0cc0 11017  1c1 11018   + caddc 11020   < clt 11157  cmin 11355  cn 12136  cz 12479  +crp 12896  ..^cfzo 13561   mod cmo 13780  abscabs 15148
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1911  ax-6 1968  ax-7 2009  ax-8 2115  ax-9 2123  ax-10 2146  ax-11 2162  ax-12 2182  ax-ext 2705  ax-sep 5238  ax-nul 5248  ax-pow 5307  ax-pr 5374  ax-un 7677  ax-cnex 11073  ax-resscn 11074  ax-1cn 11075  ax-icn 11076  ax-addcl 11077  ax-addrcl 11078  ax-mulcl 11079  ax-mulrcl 11080  ax-mulcom 11081  ax-addass 11082  ax-mulass 11083  ax-distr 11084  ax-i2m1 11085  ax-1ne0 11086  ax-1rid 11087  ax-rnegex 11088  ax-rrecex 11089  ax-cnre 11090  ax-pre-lttri 11091  ax-pre-lttrn 11092  ax-pre-ltadd 11093  ax-pre-mulgt0 11094  ax-pre-sup 11095
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3or 1087  df-3an 1088  df-tru 1544  df-fal 1554  df-ex 1781  df-nf 1785  df-sb 2068  df-mo 2537  df-eu 2566  df-clab 2712  df-cleq 2725  df-clel 2808  df-nfc 2882  df-ne 2930  df-nel 3034  df-ral 3049  df-rex 3058  df-rmo 3347  df-reu 3348  df-rab 3397  df-v 3439  df-sbc 3738  df-csb 3847  df-dif 3901  df-un 3903  df-in 3905  df-ss 3915  df-pss 3918  df-nul 4283  df-if 4477  df-pw 4553  df-sn 4578  df-pr 4580  df-op 4584  df-uni 4861  df-iun 4945  df-br 5096  df-opab 5158  df-mpt 5177  df-tr 5203  df-id 5516  df-eprel 5521  df-po 5529  df-so 5530  df-fr 5574  df-we 5576  df-xp 5627  df-rel 5628  df-cnv 5629  df-co 5630  df-dm 5631  df-rn 5632  df-res 5633  df-ima 5634  df-pred 6256  df-ord 6317  df-on 6318  df-lim 6319  df-suc 6320  df-iota 6445  df-fun 6491  df-fn 6492  df-f 6493  df-f1 6494  df-fo 6495  df-f1o 6496  df-fv 6497  df-riota 7312  df-ov 7358  df-oprab 7359  df-mpo 7360  df-om 7806  df-1st 7930  df-2nd 7931  df-frecs 8220  df-wrecs 8251  df-recs 8300  df-rdg 8338  df-er 8631  df-en 8880  df-dom 8881  df-sdom 8882  df-sup 9337  df-inf 9338  df-pnf 11159  df-mnf 11160  df-xr 11161  df-ltxr 11162  df-le 11163  df-sub 11357  df-neg 11358  df-div 11786  df-nn 12137  df-2 12199  df-3 12200  df-n0 12393  df-z 12480  df-uz 12743  df-rp 12897  df-fz 13415  df-fzo 13562  df-fl 13703  df-mod 13781  df-seq 13916  df-exp 13976  df-cj 15013  df-re 15014  df-im 15015  df-sqrt 15149  df-abs 15150  df-dvds 16171
This theorem is referenced by:  modm2nep1  47528  modp2nep1  47529  modm1nep2  47530  modm1nem2  47531
  Copyright terms: Public domain W3C validator