| Step | Hyp | Ref
| Expression |
| 1 | | simpr 477 |
. . . . . 6
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → 𝑖 ∈ ℤ) |
| 2 | 1 | adantr 481 |
. . . . 5
⊢
(((((𝐴 ∈
ℕ0 ∧ 𝑀
∈ ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) ∧ 𝐴 = ((𝑖 · 𝑀) + 𝐵)) → 𝑖 ∈ ℤ) |
| 3 | | nn0cn 11302 |
. . . . . . . . . . . 12
⊢ (𝐴 ∈ ℕ0
→ 𝐴 ∈
ℂ) |
| 4 | 3 | adantr 481 |
. . . . . . . . . . 11
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → 𝐴 ∈ ℂ) |
| 5 | 4 | ad2antrr 762 |
. . . . . . . . . 10
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → 𝐴 ∈ ℂ) |
| 6 | | nn0re 11301 |
. . . . . . . . . . . . . . 15
⊢ (𝐴 ∈ ℕ0
→ 𝐴 ∈
ℝ) |
| 7 | | modcl 12672 |
. . . . . . . . . . . . . . 15
⊢ ((𝐴 ∈ ℝ ∧ 𝑀 ∈ ℝ+)
→ (𝐴 mod 𝑀) ∈
ℝ) |
| 8 | 6, 7 | sylan 488 |
. . . . . . . . . . . . . 14
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → (𝐴 mod 𝑀) ∈ ℝ) |
| 9 | 8 | recnd 10068 |
. . . . . . . . . . . . 13
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → (𝐴 mod 𝑀) ∈ ℂ) |
| 10 | 9 | adantr 481 |
. . . . . . . . . . . 12
⊢ (((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) → (𝐴 mod 𝑀) ∈ ℂ) |
| 11 | | eleq1 2689 |
. . . . . . . . . . . . 13
⊢ ((𝐴 mod 𝑀) = 𝐵 → ((𝐴 mod 𝑀) ∈ ℂ ↔ 𝐵 ∈ ℂ)) |
| 12 | 11 | adantl 482 |
. . . . . . . . . . . 12
⊢ (((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) → ((𝐴 mod 𝑀) ∈ ℂ ↔ 𝐵 ∈ ℂ)) |
| 13 | 10, 12 | mpbid 222 |
. . . . . . . . . . 11
⊢ (((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) → 𝐵 ∈ ℂ) |
| 14 | 13 | adantr 481 |
. . . . . . . . . 10
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → 𝐵 ∈ ℂ) |
| 15 | | zcn 11382 |
. . . . . . . . . . . 12
⊢ (𝑖 ∈ ℤ → 𝑖 ∈
ℂ) |
| 16 | 15 | adantl 482 |
. . . . . . . . . . 11
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → 𝑖 ∈ ℂ) |
| 17 | | rpcn 11841 |
. . . . . . . . . . . . 13
⊢ (𝑀 ∈ ℝ+
→ 𝑀 ∈
ℂ) |
| 18 | 17 | adantl 482 |
. . . . . . . . . . . 12
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → 𝑀 ∈ ℂ) |
| 19 | 18 | ad2antrr 762 |
. . . . . . . . . . 11
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → 𝑀 ∈ ℂ) |
| 20 | 16, 19 | mulcld 10060 |
. . . . . . . . . 10
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → (𝑖 · 𝑀) ∈ ℂ) |
| 21 | 5, 14, 20 | subadd2d 10411 |
. . . . . . . . 9
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → ((𝐴 − 𝐵) = (𝑖 · 𝑀) ↔ ((𝑖 · 𝑀) + 𝐵) = 𝐴)) |
| 22 | | eqcom 2629 |
. . . . . . . . 9
⊢ (𝐴 = ((𝑖 · 𝑀) + 𝐵) ↔ ((𝑖 · 𝑀) + 𝐵) = 𝐴) |
| 23 | 21, 22 | syl6rbbr 279 |
. . . . . . . 8
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → (𝐴 = ((𝑖 · 𝑀) + 𝐵) ↔ (𝐴 − 𝐵) = (𝑖 · 𝑀))) |
| 24 | 3 | ad2antrr 762 |
. . . . . . . . . . 11
⊢ (((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) → 𝐴 ∈ ℂ) |
| 25 | 24, 13 | subcld 10392 |
. . . . . . . . . 10
⊢ (((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) → (𝐴 − 𝐵) ∈ ℂ) |
| 26 | 25 | adantr 481 |
. . . . . . . . 9
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → (𝐴 − 𝐵) ∈ ℂ) |
| 27 | | rpcnne0 11850 |
. . . . . . . . . . 11
⊢ (𝑀 ∈ ℝ+
→ (𝑀 ∈ ℂ
∧ 𝑀 ≠
0)) |
| 28 | 27 | adantl 482 |
. . . . . . . . . 10
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → (𝑀 ∈ ℂ ∧ 𝑀 ≠ 0)) |
| 29 | 28 | ad2antrr 762 |
. . . . . . . . 9
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → (𝑀 ∈ ℂ ∧ 𝑀 ≠ 0)) |
| 30 | | divmul3 10690 |
. . . . . . . . 9
⊢ (((𝐴 − 𝐵) ∈ ℂ ∧ 𝑖 ∈ ℂ ∧ (𝑀 ∈ ℂ ∧ 𝑀 ≠ 0)) → (((𝐴 − 𝐵) / 𝑀) = 𝑖 ↔ (𝐴 − 𝐵) = (𝑖 · 𝑀))) |
| 31 | 26, 16, 29, 30 | syl3anc 1326 |
. . . . . . . 8
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → (((𝐴 − 𝐵) / 𝑀) = 𝑖 ↔ (𝐴 − 𝐵) = (𝑖 · 𝑀))) |
| 32 | | oveq2 6658 |
. . . . . . . . . . . . . 14
⊢ (𝐵 = (𝐴 mod 𝑀) → (𝐴 − 𝐵) = (𝐴 − (𝐴 mod 𝑀))) |
| 33 | 32 | oveq1d 6665 |
. . . . . . . . . . . . 13
⊢ (𝐵 = (𝐴 mod 𝑀) → ((𝐴 − 𝐵) / 𝑀) = ((𝐴 − (𝐴 mod 𝑀)) / 𝑀)) |
| 34 | 33 | eqcoms 2630 |
. . . . . . . . . . . 12
⊢ ((𝐴 mod 𝑀) = 𝐵 → ((𝐴 − 𝐵) / 𝑀) = ((𝐴 − (𝐴 mod 𝑀)) / 𝑀)) |
| 35 | 34 | adantl 482 |
. . . . . . . . . . 11
⊢ (((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) → ((𝐴 − 𝐵) / 𝑀) = ((𝐴 − (𝐴 mod 𝑀)) / 𝑀)) |
| 36 | 35 | adantr 481 |
. . . . . . . . . 10
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → ((𝐴 − 𝐵) / 𝑀) = ((𝐴 − (𝐴 mod 𝑀)) / 𝑀)) |
| 37 | | moddiffl 12681 |
. . . . . . . . . . . 12
⊢ ((𝐴 ∈ ℝ ∧ 𝑀 ∈ ℝ+)
→ ((𝐴 − (𝐴 mod 𝑀)) / 𝑀) = (⌊‘(𝐴 / 𝑀))) |
| 38 | 6, 37 | sylan 488 |
. . . . . . . . . . 11
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → ((𝐴 − (𝐴 mod 𝑀)) / 𝑀) = (⌊‘(𝐴 / 𝑀))) |
| 39 | 38 | ad2antrr 762 |
. . . . . . . . . 10
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → ((𝐴 − (𝐴 mod 𝑀)) / 𝑀) = (⌊‘(𝐴 / 𝑀))) |
| 40 | 36, 39 | eqtrd 2656 |
. . . . . . . . 9
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → ((𝐴 − 𝐵) / 𝑀) = (⌊‘(𝐴 / 𝑀))) |
| 41 | 40 | eqeq1d 2624 |
. . . . . . . 8
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → (((𝐴 − 𝐵) / 𝑀) = 𝑖 ↔ (⌊‘(𝐴 / 𝑀)) = 𝑖)) |
| 42 | 23, 31, 41 | 3bitr2d 296 |
. . . . . . 7
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → (𝐴 = ((𝑖 · 𝑀) + 𝐵) ↔ (⌊‘(𝐴 / 𝑀)) = 𝑖)) |
| 43 | | nn0ge0 11318 |
. . . . . . . . . . . 12
⊢ (𝐴 ∈ ℕ0
→ 0 ≤ 𝐴) |
| 44 | 6, 43 | jca 554 |
. . . . . . . . . . 11
⊢ (𝐴 ∈ ℕ0
→ (𝐴 ∈ ℝ
∧ 0 ≤ 𝐴)) |
| 45 | | rpregt0 11846 |
. . . . . . . . . . 11
⊢ (𝑀 ∈ ℝ+
→ (𝑀 ∈ ℝ
∧ 0 < 𝑀)) |
| 46 | | divge0 10892 |
. . . . . . . . . . 11
⊢ (((𝐴 ∈ ℝ ∧ 0 ≤
𝐴) ∧ (𝑀 ∈ ℝ ∧ 0 < 𝑀)) → 0 ≤ (𝐴 / 𝑀)) |
| 47 | 44, 45, 46 | syl2an 494 |
. . . . . . . . . 10
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → 0 ≤ (𝐴 / 𝑀)) |
| 48 | 6 | adantr 481 |
. . . . . . . . . . . 12
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → 𝐴 ∈ ℝ) |
| 49 | | rpre 11839 |
. . . . . . . . . . . . 13
⊢ (𝑀 ∈ ℝ+
→ 𝑀 ∈
ℝ) |
| 50 | 49 | adantl 482 |
. . . . . . . . . . . 12
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → 𝑀 ∈ ℝ) |
| 51 | | rpne0 11848 |
. . . . . . . . . . . . 13
⊢ (𝑀 ∈ ℝ+
→ 𝑀 ≠
0) |
| 52 | 51 | adantl 482 |
. . . . . . . . . . . 12
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → 𝑀 ≠ 0) |
| 53 | 48, 50, 52 | redivcld 10853 |
. . . . . . . . . . 11
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → (𝐴 / 𝑀) ∈ ℝ) |
| 54 | | 0z 11388 |
. . . . . . . . . . 11
⊢ 0 ∈
ℤ |
| 55 | | flge 12606 |
. . . . . . . . . . 11
⊢ (((𝐴 / 𝑀) ∈ ℝ ∧ 0 ∈ ℤ)
→ (0 ≤ (𝐴 / 𝑀) ↔ 0 ≤
(⌊‘(𝐴 / 𝑀)))) |
| 56 | 53, 54, 55 | sylancl 694 |
. . . . . . . . . 10
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → (0 ≤ (𝐴 / 𝑀) ↔ 0 ≤ (⌊‘(𝐴 / 𝑀)))) |
| 57 | 47, 56 | mpbid 222 |
. . . . . . . . 9
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → 0 ≤ (⌊‘(𝐴 / 𝑀))) |
| 58 | | breq2 4657 |
. . . . . . . . 9
⊢
((⌊‘(𝐴 /
𝑀)) = 𝑖 → (0 ≤ (⌊‘(𝐴 / 𝑀)) ↔ 0 ≤ 𝑖)) |
| 59 | 57, 58 | syl5ibcom 235 |
. . . . . . . 8
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → ((⌊‘(𝐴 / 𝑀)) = 𝑖 → 0 ≤ 𝑖)) |
| 60 | 59 | ad2antrr 762 |
. . . . . . 7
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) →
((⌊‘(𝐴 / 𝑀)) = 𝑖 → 0 ≤ 𝑖)) |
| 61 | 42, 60 | sylbid 230 |
. . . . . 6
⊢ ((((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) → (𝐴 = ((𝑖 · 𝑀) + 𝐵) → 0 ≤ 𝑖)) |
| 62 | 61 | imp 445 |
. . . . 5
⊢
(((((𝐴 ∈
ℕ0 ∧ 𝑀
∈ ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) ∧ 𝐴 = ((𝑖 · 𝑀) + 𝐵)) → 0 ≤ 𝑖) |
| 63 | | elnn0z 11390 |
. . . . 5
⊢ (𝑖 ∈ ℕ0
↔ (𝑖 ∈ ℤ
∧ 0 ≤ 𝑖)) |
| 64 | 2, 62, 63 | sylanbrc 698 |
. . . 4
⊢
(((((𝐴 ∈
ℕ0 ∧ 𝑀
∈ ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) ∧ 𝐴 = ((𝑖 · 𝑀) + 𝐵)) → 𝑖 ∈ ℕ0) |
| 65 | | oveq1 6657 |
. . . . . . 7
⊢ (𝑘 = 𝑖 → (𝑘 · 𝑀) = (𝑖 · 𝑀)) |
| 66 | 65 | oveq1d 6665 |
. . . . . 6
⊢ (𝑘 = 𝑖 → ((𝑘 · 𝑀) + 𝐵) = ((𝑖 · 𝑀) + 𝐵)) |
| 67 | 66 | eqeq2d 2632 |
. . . . 5
⊢ (𝑘 = 𝑖 → (𝐴 = ((𝑘 · 𝑀) + 𝐵) ↔ 𝐴 = ((𝑖 · 𝑀) + 𝐵))) |
| 68 | 67 | adantl 482 |
. . . 4
⊢
((((((𝐴 ∈
ℕ0 ∧ 𝑀
∈ ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) ∧ 𝐴 = ((𝑖 · 𝑀) + 𝐵)) ∧ 𝑘 = 𝑖) → (𝐴 = ((𝑘 · 𝑀) + 𝐵) ↔ 𝐴 = ((𝑖 · 𝑀) + 𝐵))) |
| 69 | | simpr 477 |
. . . 4
⊢
(((((𝐴 ∈
ℕ0 ∧ 𝑀
∈ ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) ∧ 𝐴 = ((𝑖 · 𝑀) + 𝐵)) → 𝐴 = ((𝑖 · 𝑀) + 𝐵)) |
| 70 | 64, 68, 69 | rspcedvd 3317 |
. . 3
⊢
(((((𝐴 ∈
ℕ0 ∧ 𝑀
∈ ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) ∧ 𝑖 ∈ ℤ) ∧ 𝐴 = ((𝑖 · 𝑀) + 𝐵)) → ∃𝑘 ∈ ℕ0 𝐴 = ((𝑘 · 𝑀) + 𝐵)) |
| 71 | | nn0z 11400 |
. . . . 5
⊢ (𝐴 ∈ ℕ0
→ 𝐴 ∈
ℤ) |
| 72 | | modmuladdim 12713 |
. . . . 5
⊢ ((𝐴 ∈ ℤ ∧ 𝑀 ∈ ℝ+)
→ ((𝐴 mod 𝑀) = 𝐵 → ∃𝑖 ∈ ℤ 𝐴 = ((𝑖 · 𝑀) + 𝐵))) |
| 73 | 71, 72 | sylan 488 |
. . . 4
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → ((𝐴 mod 𝑀) = 𝐵 → ∃𝑖 ∈ ℤ 𝐴 = ((𝑖 · 𝑀) + 𝐵))) |
| 74 | 73 | imp 445 |
. . 3
⊢ (((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) → ∃𝑖 ∈ ℤ 𝐴 = ((𝑖 · 𝑀) + 𝐵)) |
| 75 | 70, 74 | r19.29a 3078 |
. 2
⊢ (((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) ∧ (𝐴 mod 𝑀) = 𝐵) → ∃𝑘 ∈ ℕ0 𝐴 = ((𝑘 · 𝑀) + 𝐵)) |
| 76 | 75 | ex 450 |
1
⊢ ((𝐴 ∈ ℕ0
∧ 𝑀 ∈
ℝ+) → ((𝐴 mod 𝑀) = 𝐵 → ∃𝑘 ∈ ℕ0 𝐴 = ((𝑘 · 𝑀) + 𝐵))) |