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

Theorem prmirredlem 21506
Description: A positive integer is irreducible over iff it is a prime number. (Contributed by Mario Carneiro, 5-Dec-2014.) (Revised by AV, 10-Jun-2019.)
Hypothesis
Ref Expression
prmirred.i 𝐼 = (Irred‘ℤring)
Assertion
Ref Expression
prmirredlem (𝐴 ∈ ℕ → (𝐴𝐼𝐴 ∈ ℙ))

Proof of Theorem prmirredlem
Dummy variables 𝑥 𝑦 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 zringring 21483 . . . . . 6 ring ∈ Ring
2 prmirred.i . . . . . . 7 𝐼 = (Irred‘ℤring)
3 zring1 21493 . . . . . . 7 1 = (1r‘ℤring)
42, 3irredn1 20452 . . . . . 6 ((ℤring ∈ Ring ∧ 𝐴𝐼) → 𝐴 ≠ 1)
51, 4mpan 689 . . . . 5 (𝐴𝐼𝐴 ≠ 1)
65anim2i 616 . . . 4 ((𝐴 ∈ ℕ ∧ 𝐴𝐼) → (𝐴 ∈ ℕ ∧ 𝐴 ≠ 1))
7 eluz2b3 12987 . . . 4 (𝐴 ∈ (ℤ‘2) ↔ (𝐴 ∈ ℕ ∧ 𝐴 ≠ 1))
86, 7sylibr 234 . . 3 ((𝐴 ∈ ℕ ∧ 𝐴𝐼) → 𝐴 ∈ (ℤ‘2))
9 nnz 12660 . . . . . . . 8 (𝑦 ∈ ℕ → 𝑦 ∈ ℤ)
109ad2antrl 727 . . . . . . 7 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 𝑦 ∈ ℤ)
11 simprr 772 . . . . . . . 8 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 𝑦𝐴)
12 nnne0 12327 . . . . . . . . . 10 (𝑦 ∈ ℕ → 𝑦 ≠ 0)
1312ad2antrl 727 . . . . . . . . 9 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 𝑦 ≠ 0)
14 nnz 12660 . . . . . . . . . 10 (𝐴 ∈ ℕ → 𝐴 ∈ ℤ)
1514ad2antrr 725 . . . . . . . . 9 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 𝐴 ∈ ℤ)
16 dvdsval2 16305 . . . . . . . . 9 ((𝑦 ∈ ℤ ∧ 𝑦 ≠ 0 ∧ 𝐴 ∈ ℤ) → (𝑦𝐴 ↔ (𝐴 / 𝑦) ∈ ℤ))
1710, 13, 15, 16syl3anc 1371 . . . . . . . 8 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (𝑦𝐴 ↔ (𝐴 / 𝑦) ∈ ℤ))
1811, 17mpbid 232 . . . . . . 7 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (𝐴 / 𝑦) ∈ ℤ)
1915zcnd 12748 . . . . . . . . 9 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 𝐴 ∈ ℂ)
20 nncn 12301 . . . . . . . . . 10 (𝑦 ∈ ℕ → 𝑦 ∈ ℂ)
2120ad2antrl 727 . . . . . . . . 9 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 𝑦 ∈ ℂ)
2219, 21, 13divcan2d 12072 . . . . . . . 8 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (𝑦 · (𝐴 / 𝑦)) = 𝐴)
23 simplr 768 . . . . . . . 8 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 𝐴𝐼)
2422, 23eqeltrd 2844 . . . . . . 7 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (𝑦 · (𝐴 / 𝑦)) ∈ 𝐼)
25 zringbas 21487 . . . . . . . 8 ℤ = (Base‘ℤring)
26 eqid 2740 . . . . . . . 8 (Unit‘ℤring) = (Unit‘ℤring)
27 zringmulr 21491 . . . . . . . 8 · = (.r‘ℤring)
282, 25, 26, 27irredmul 20455 . . . . . . 7 ((𝑦 ∈ ℤ ∧ (𝐴 / 𝑦) ∈ ℤ ∧ (𝑦 · (𝐴 / 𝑦)) ∈ 𝐼) → (𝑦 ∈ (Unit‘ℤring) ∨ (𝐴 / 𝑦) ∈ (Unit‘ℤring)))
2910, 18, 24, 28syl3anc 1371 . . . . . 6 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (𝑦 ∈ (Unit‘ℤring) ∨ (𝐴 / 𝑦) ∈ (Unit‘ℤring)))
30 zringunit 21500 . . . . . . . . . 10 (𝑦 ∈ (Unit‘ℤring) ↔ (𝑦 ∈ ℤ ∧ (abs‘𝑦) = 1))
3130baib 535 . . . . . . . . 9 (𝑦 ∈ ℤ → (𝑦 ∈ (Unit‘ℤring) ↔ (abs‘𝑦) = 1))
3210, 31syl 17 . . . . . . . 8 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (𝑦 ∈ (Unit‘ℤring) ↔ (abs‘𝑦) = 1))
33 nnnn0 12560 . . . . . . . . . . 11 (𝑦 ∈ ℕ → 𝑦 ∈ ℕ0)
34 nn0re 12562 . . . . . . . . . . . 12 (𝑦 ∈ ℕ0𝑦 ∈ ℝ)
35 nn0ge0 12578 . . . . . . . . . . . 12 (𝑦 ∈ ℕ0 → 0 ≤ 𝑦)
3634, 35absidd 15471 . . . . . . . . . . 11 (𝑦 ∈ ℕ0 → (abs‘𝑦) = 𝑦)
3733, 36syl 17 . . . . . . . . . 10 (𝑦 ∈ ℕ → (abs‘𝑦) = 𝑦)
3837ad2antrl 727 . . . . . . . . 9 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (abs‘𝑦) = 𝑦)
3938eqeq1d 2742 . . . . . . . 8 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → ((abs‘𝑦) = 1 ↔ 𝑦 = 1))
4032, 39bitrd 279 . . . . . . 7 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (𝑦 ∈ (Unit‘ℤring) ↔ 𝑦 = 1))
41 zringunit 21500 . . . . . . . . . 10 ((𝐴 / 𝑦) ∈ (Unit‘ℤring) ↔ ((𝐴 / 𝑦) ∈ ℤ ∧ (abs‘(𝐴 / 𝑦)) = 1))
4241baib 535 . . . . . . . . 9 ((𝐴 / 𝑦) ∈ ℤ → ((𝐴 / 𝑦) ∈ (Unit‘ℤring) ↔ (abs‘(𝐴 / 𝑦)) = 1))
4318, 42syl 17 . . . . . . . 8 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → ((𝐴 / 𝑦) ∈ (Unit‘ℤring) ↔ (abs‘(𝐴 / 𝑦)) = 1))
44 nnre 12300 . . . . . . . . . . . . 13 (𝐴 ∈ ℕ → 𝐴 ∈ ℝ)
4544ad2antrr 725 . . . . . . . . . . . 12 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 𝐴 ∈ ℝ)
46 simprl 770 . . . . . . . . . . . 12 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 𝑦 ∈ ℕ)
4745, 46nndivred 12347 . . . . . . . . . . 11 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (𝐴 / 𝑦) ∈ ℝ)
48 nnnn0 12560 . . . . . . . . . . . . . 14 (𝐴 ∈ ℕ → 𝐴 ∈ ℕ0)
49 nn0ge0 12578 . . . . . . . . . . . . . 14 (𝐴 ∈ ℕ0 → 0 ≤ 𝐴)
5048, 49syl 17 . . . . . . . . . . . . 13 (𝐴 ∈ ℕ → 0 ≤ 𝐴)
5150ad2antrr 725 . . . . . . . . . . . 12 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 0 ≤ 𝐴)
5246nnred 12308 . . . . . . . . . . . 12 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 𝑦 ∈ ℝ)
53 nngt0 12324 . . . . . . . . . . . . 13 (𝑦 ∈ ℕ → 0 < 𝑦)
5453ad2antrl 727 . . . . . . . . . . . 12 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 0 < 𝑦)
55 divge0 12164 . . . . . . . . . . . 12 (((𝐴 ∈ ℝ ∧ 0 ≤ 𝐴) ∧ (𝑦 ∈ ℝ ∧ 0 < 𝑦)) → 0 ≤ (𝐴 / 𝑦))
5645, 51, 52, 54, 55syl22anc 838 . . . . . . . . . . 11 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 0 ≤ (𝐴 / 𝑦))
5747, 56absidd 15471 . . . . . . . . . 10 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (abs‘(𝐴 / 𝑦)) = (𝐴 / 𝑦))
5857eqeq1d 2742 . . . . . . . . 9 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → ((abs‘(𝐴 / 𝑦)) = 1 ↔ (𝐴 / 𝑦) = 1))
59 1cnd 11285 . . . . . . . . . 10 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → 1 ∈ ℂ)
6019, 21, 59, 13divmuld 12092 . . . . . . . . 9 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → ((𝐴 / 𝑦) = 1 ↔ (𝑦 · 1) = 𝐴))
6121mulridd 11307 . . . . . . . . . 10 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (𝑦 · 1) = 𝑦)
6261eqeq1d 2742 . . . . . . . . 9 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → ((𝑦 · 1) = 𝐴𝑦 = 𝐴))
6358, 60, 623bitrd 305 . . . . . . . 8 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → ((abs‘(𝐴 / 𝑦)) = 1 ↔ 𝑦 = 𝐴))
6443, 63bitrd 279 . . . . . . 7 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → ((𝐴 / 𝑦) ∈ (Unit‘ℤring) ↔ 𝑦 = 𝐴))
6540, 64orbi12d 917 . . . . . 6 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → ((𝑦 ∈ (Unit‘ℤring) ∨ (𝐴 / 𝑦) ∈ (Unit‘ℤring)) ↔ (𝑦 = 1 ∨ 𝑦 = 𝐴)))
6629, 65mpbid 232 . . . . 5 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ (𝑦 ∈ ℕ ∧ 𝑦𝐴)) → (𝑦 = 1 ∨ 𝑦 = 𝐴))
6766expr 456 . . . 4 (((𝐴 ∈ ℕ ∧ 𝐴𝐼) ∧ 𝑦 ∈ ℕ) → (𝑦𝐴 → (𝑦 = 1 ∨ 𝑦 = 𝐴)))
6867ralrimiva 3152 . . 3 ((𝐴 ∈ ℕ ∧ 𝐴𝐼) → ∀𝑦 ∈ ℕ (𝑦𝐴 → (𝑦 = 1 ∨ 𝑦 = 𝐴)))
69 isprm2 16729 . . 3 (𝐴 ∈ ℙ ↔ (𝐴 ∈ (ℤ‘2) ∧ ∀𝑦 ∈ ℕ (𝑦𝐴 → (𝑦 = 1 ∨ 𝑦 = 𝐴))))
708, 68, 69sylanbrc 582 . 2 ((𝐴 ∈ ℕ ∧ 𝐴𝐼) → 𝐴 ∈ ℙ)
71 prmz 16722 . . . 4 (𝐴 ∈ ℙ → 𝐴 ∈ ℤ)
72 1nprm 16726 . . . . 5 ¬ 1 ∈ ℙ
73 zringunit 21500 . . . . . 6 (𝐴 ∈ (Unit‘ℤring) ↔ (𝐴 ∈ ℤ ∧ (abs‘𝐴) = 1))
74 prmnn 16721 . . . . . . . . . 10 (𝐴 ∈ ℙ → 𝐴 ∈ ℕ)
75 nn0re 12562 . . . . . . . . . . 11 (𝐴 ∈ ℕ0𝐴 ∈ ℝ)
7675, 49absidd 15471 . . . . . . . . . 10 (𝐴 ∈ ℕ0 → (abs‘𝐴) = 𝐴)
7774, 48, 763syl 18 . . . . . . . . 9 (𝐴 ∈ ℙ → (abs‘𝐴) = 𝐴)
78 id 22 . . . . . . . . 9 (𝐴 ∈ ℙ → 𝐴 ∈ ℙ)
7977, 78eqeltrd 2844 . . . . . . . 8 (𝐴 ∈ ℙ → (abs‘𝐴) ∈ ℙ)
80 eleq1 2832 . . . . . . . 8 ((abs‘𝐴) = 1 → ((abs‘𝐴) ∈ ℙ ↔ 1 ∈ ℙ))
8179, 80syl5ibcom 245 . . . . . . 7 (𝐴 ∈ ℙ → ((abs‘𝐴) = 1 → 1 ∈ ℙ))
8281adantld 490 . . . . . 6 (𝐴 ∈ ℙ → ((𝐴 ∈ ℤ ∧ (abs‘𝐴) = 1) → 1 ∈ ℙ))
8373, 82biimtrid 242 . . . . 5 (𝐴 ∈ ℙ → (𝐴 ∈ (Unit‘ℤring) → 1 ∈ ℙ))
8472, 83mtoi 199 . . . 4 (𝐴 ∈ ℙ → ¬ 𝐴 ∈ (Unit‘ℤring))
85 dvdsmul1 16326 . . . . . . . . . . 11 ((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ) → 𝑥 ∥ (𝑥 · 𝑦))
8685ad2antlr 726 . . . . . . . . . 10 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 𝑥 ∥ (𝑥 · 𝑦))
87 simpr 484 . . . . . . . . . 10 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (𝑥 · 𝑦) = 𝐴)
8886, 87breqtrd 5192 . . . . . . . . 9 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 𝑥𝐴)
89 simplrl 776 . . . . . . . . . 10 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 𝑥 ∈ ℤ)
9071ad2antrr 725 . . . . . . . . . 10 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 𝐴 ∈ ℤ)
91 absdvdsb 16323 . . . . . . . . . 10 ((𝑥 ∈ ℤ ∧ 𝐴 ∈ ℤ) → (𝑥𝐴 ↔ (abs‘𝑥) ∥ 𝐴))
9289, 90, 91syl2anc 583 . . . . . . . . 9 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (𝑥𝐴 ↔ (abs‘𝑥) ∥ 𝐴))
9388, 92mpbid 232 . . . . . . . 8 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘𝑥) ∥ 𝐴)
94 breq1 5169 . . . . . . . . . 10 (𝑦 = (abs‘𝑥) → (𝑦𝐴 ↔ (abs‘𝑥) ∥ 𝐴))
95 eqeq1 2744 . . . . . . . . . . 11 (𝑦 = (abs‘𝑥) → (𝑦 = 1 ↔ (abs‘𝑥) = 1))
96 eqeq1 2744 . . . . . . . . . . 11 (𝑦 = (abs‘𝑥) → (𝑦 = 𝐴 ↔ (abs‘𝑥) = 𝐴))
9795, 96orbi12d 917 . . . . . . . . . 10 (𝑦 = (abs‘𝑥) → ((𝑦 = 1 ∨ 𝑦 = 𝐴) ↔ ((abs‘𝑥) = 1 ∨ (abs‘𝑥) = 𝐴)))
9894, 97imbi12d 344 . . . . . . . . 9 (𝑦 = (abs‘𝑥) → ((𝑦𝐴 → (𝑦 = 1 ∨ 𝑦 = 𝐴)) ↔ ((abs‘𝑥) ∥ 𝐴 → ((abs‘𝑥) = 1 ∨ (abs‘𝑥) = 𝐴))))
9969simprbi 496 . . . . . . . . . 10 (𝐴 ∈ ℙ → ∀𝑦 ∈ ℕ (𝑦𝐴 → (𝑦 = 1 ∨ 𝑦 = 𝐴)))
10099ad2antrr 725 . . . . . . . . 9 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → ∀𝑦 ∈ ℕ (𝑦𝐴 → (𝑦 = 1 ∨ 𝑦 = 𝐴)))
10189zcnd 12748 . . . . . . . . . . . 12 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 𝑥 ∈ ℂ)
10274ad2antrr 725 . . . . . . . . . . . . . . 15 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 𝐴 ∈ ℕ)
103102nnne0d 12343 . . . . . . . . . . . . . 14 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 𝐴 ≠ 0)
104 simplrr 777 . . . . . . . . . . . . . . . 16 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 𝑦 ∈ ℤ)
105104zcnd 12748 . . . . . . . . . . . . . . 15 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 𝑦 ∈ ℂ)
106105mul02d 11488 . . . . . . . . . . . . . 14 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (0 · 𝑦) = 0)
107103, 87, 1063netr4d 3024 . . . . . . . . . . . . 13 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (𝑥 · 𝑦) ≠ (0 · 𝑦))
108 oveq1 7455 . . . . . . . . . . . . . 14 (𝑥 = 0 → (𝑥 · 𝑦) = (0 · 𝑦))
109108necon3i 2979 . . . . . . . . . . . . 13 ((𝑥 · 𝑦) ≠ (0 · 𝑦) → 𝑥 ≠ 0)
110107, 109syl 17 . . . . . . . . . . . 12 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 𝑥 ≠ 0)
111101, 110absne0d 15496 . . . . . . . . . . 11 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘𝑥) ≠ 0)
112111neneqd 2951 . . . . . . . . . 10 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → ¬ (abs‘𝑥) = 0)
113 nn0abscl 15361 . . . . . . . . . . . . 13 (𝑥 ∈ ℤ → (abs‘𝑥) ∈ ℕ0)
11489, 113syl 17 . . . . . . . . . . . 12 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘𝑥) ∈ ℕ0)
115 elnn0 12555 . . . . . . . . . . . 12 ((abs‘𝑥) ∈ ℕ0 ↔ ((abs‘𝑥) ∈ ℕ ∨ (abs‘𝑥) = 0))
116114, 115sylib 218 . . . . . . . . . . 11 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → ((abs‘𝑥) ∈ ℕ ∨ (abs‘𝑥) = 0))
117116ord 863 . . . . . . . . . 10 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (¬ (abs‘𝑥) ∈ ℕ → (abs‘𝑥) = 0))
118112, 117mt3d 148 . . . . . . . . 9 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘𝑥) ∈ ℕ)
11998, 100, 118rspcdva 3636 . . . . . . . 8 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → ((abs‘𝑥) ∥ 𝐴 → ((abs‘𝑥) = 1 ∨ (abs‘𝑥) = 𝐴)))
12093, 119mpd 15 . . . . . . 7 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → ((abs‘𝑥) = 1 ∨ (abs‘𝑥) = 𝐴))
121 zringunit 21500 . . . . . . . . . 10 (𝑥 ∈ (Unit‘ℤring) ↔ (𝑥 ∈ ℤ ∧ (abs‘𝑥) = 1))
122121baib 535 . . . . . . . . 9 (𝑥 ∈ ℤ → (𝑥 ∈ (Unit‘ℤring) ↔ (abs‘𝑥) = 1))
12389, 122syl 17 . . . . . . . 8 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (𝑥 ∈ (Unit‘ℤring) ↔ (abs‘𝑥) = 1))
124104, 31syl 17 . . . . . . . . 9 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (𝑦 ∈ (Unit‘ℤring) ↔ (abs‘𝑦) = 1))
125105abscld 15485 . . . . . . . . . . 11 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘𝑦) ∈ ℝ)
126125recnd 11318 . . . . . . . . . 10 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘𝑦) ∈ ℂ)
127 1cnd 11285 . . . . . . . . . 10 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → 1 ∈ ℂ)
128101abscld 15485 . . . . . . . . . . 11 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘𝑥) ∈ ℝ)
129128recnd 11318 . . . . . . . . . 10 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘𝑥) ∈ ℂ)
130126, 127, 129, 111mulcand 11923 . . . . . . . . 9 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (((abs‘𝑥) · (abs‘𝑦)) = ((abs‘𝑥) · 1) ↔ (abs‘𝑦) = 1))
13187fveq2d 6924 . . . . . . . . . . . 12 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘(𝑥 · 𝑦)) = (abs‘𝐴))
132101, 105absmuld 15503 . . . . . . . . . . . 12 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘(𝑥 · 𝑦)) = ((abs‘𝑥) · (abs‘𝑦)))
13377ad2antrr 725 . . . . . . . . . . . 12 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (abs‘𝐴) = 𝐴)
134131, 132, 1333eqtr3d 2788 . . . . . . . . . . 11 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → ((abs‘𝑥) · (abs‘𝑦)) = 𝐴)
135129mulridd 11307 . . . . . . . . . . 11 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → ((abs‘𝑥) · 1) = (abs‘𝑥))
136134, 135eqeq12d 2756 . . . . . . . . . 10 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (((abs‘𝑥) · (abs‘𝑦)) = ((abs‘𝑥) · 1) ↔ 𝐴 = (abs‘𝑥)))
137 eqcom 2747 . . . . . . . . . 10 (𝐴 = (abs‘𝑥) ↔ (abs‘𝑥) = 𝐴)
138136, 137bitrdi 287 . . . . . . . . 9 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (((abs‘𝑥) · (abs‘𝑦)) = ((abs‘𝑥) · 1) ↔ (abs‘𝑥) = 𝐴))
139124, 130, 1383bitr2d 307 . . . . . . . 8 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (𝑦 ∈ (Unit‘ℤring) ↔ (abs‘𝑥) = 𝐴))
140123, 139orbi12d 917 . . . . . . 7 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → ((𝑥 ∈ (Unit‘ℤring) ∨ 𝑦 ∈ (Unit‘ℤring)) ↔ ((abs‘𝑥) = 1 ∨ (abs‘𝑥) = 𝐴)))
141120, 140mpbird 257 . . . . . 6 (((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) ∧ (𝑥 · 𝑦) = 𝐴) → (𝑥 ∈ (Unit‘ℤring) ∨ 𝑦 ∈ (Unit‘ℤring)))
142141ex 412 . . . . 5 ((𝐴 ∈ ℙ ∧ (𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ)) → ((𝑥 · 𝑦) = 𝐴 → (𝑥 ∈ (Unit‘ℤring) ∨ 𝑦 ∈ (Unit‘ℤring))))
143142ralrimivva 3208 . . . 4 (𝐴 ∈ ℙ → ∀𝑥 ∈ ℤ ∀𝑦 ∈ ℤ ((𝑥 · 𝑦) = 𝐴 → (𝑥 ∈ (Unit‘ℤring) ∨ 𝑦 ∈ (Unit‘ℤring))))
14425, 26, 2, 27isirred2 20447 . . . 4 (𝐴𝐼 ↔ (𝐴 ∈ ℤ ∧ ¬ 𝐴 ∈ (Unit‘ℤring) ∧ ∀𝑥 ∈ ℤ ∀𝑦 ∈ ℤ ((𝑥 · 𝑦) = 𝐴 → (𝑥 ∈ (Unit‘ℤring) ∨ 𝑦 ∈ (Unit‘ℤring)))))
14571, 84, 143, 144syl3anbrc 1343 . . 3 (𝐴 ∈ ℙ → 𝐴𝐼)
146145adantl 481 . 2 ((𝐴 ∈ ℕ ∧ 𝐴 ∈ ℙ) → 𝐴𝐼)
14770, 146impbida 800 1 (𝐴 ∈ ℕ → (𝐴𝐼𝐴 ∈ ℙ))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 206  wa 395  wo 846   = wceq 1537  wcel 2108  wne 2946  wral 3067   class class class wbr 5166  cfv 6573  (class class class)co 7448  cc 11182  cr 11183  0cc0 11184  1c1 11185   · cmul 11189   < clt 11324  cle 11325   / cdiv 11947  cn 12293  2c2 12348  0cn0 12553  cz 12639  cuz 12903  abscabs 15283  cdvds 16302  cprime 16718  Ringcrg 20260  Unitcui 20381  Irredcir 20382  ringczring 21480
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1793  ax-4 1807  ax-5 1909  ax-6 1967  ax-7 2007  ax-8 2110  ax-9 2118  ax-10 2141  ax-11 2158  ax-12 2178  ax-ext 2711  ax-rep 5303  ax-sep 5317  ax-nul 5324  ax-pow 5383  ax-pr 5447  ax-un 7770  ax-cnex 11240  ax-resscn 11241  ax-1cn 11242  ax-icn 11243  ax-addcl 11244  ax-addrcl 11245  ax-mulcl 11246  ax-mulrcl 11247  ax-mulcom 11248  ax-addass 11249  ax-mulass 11250  ax-distr 11251  ax-i2m1 11252  ax-1ne0 11253  ax-1rid 11254  ax-rnegex 11255  ax-rrecex 11256  ax-cnre 11257  ax-pre-lttri 11258  ax-pre-lttrn 11259  ax-pre-ltadd 11260  ax-pre-mulgt0 11261  ax-pre-sup 11262  ax-addf 11263  ax-mulf 11264
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 847  df-3or 1088  df-3an 1089  df-tru 1540  df-fal 1550  df-ex 1778  df-nf 1782  df-sb 2065  df-mo 2543  df-eu 2572  df-clab 2718  df-cleq 2732  df-clel 2819  df-nfc 2895  df-ne 2947  df-nel 3053  df-ral 3068  df-rex 3077  df-rmo 3388  df-reu 3389  df-rab 3444  df-v 3490  df-sbc 3805  df-csb 3922  df-dif 3979  df-un 3981  df-in 3983  df-ss 3993  df-pss 3996  df-nul 4353  df-if 4549  df-pw 4624  df-sn 4649  df-pr 4651  df-tp 4653  df-op 4655  df-uni 4932  df-iun 5017  df-br 5167  df-opab 5229  df-mpt 5250  df-tr 5284  df-id 5593  df-eprel 5599  df-po 5607  df-so 5608  df-fr 5652  df-we 5654  df-xp 5706  df-rel 5707  df-cnv 5708  df-co 5709  df-dm 5710  df-rn 5711  df-res 5712  df-ima 5713  df-pred 6332  df-ord 6398  df-on 6399  df-lim 6400  df-suc 6401  df-iota 6525  df-fun 6575  df-fn 6576  df-f 6577  df-f1 6578  df-fo 6579  df-f1o 6580  df-fv 6581  df-riota 7404  df-ov 7451  df-oprab 7452  df-mpo 7453  df-om 7904  df-1st 8030  df-2nd 8031  df-tpos 8267  df-frecs 8322  df-wrecs 8353  df-recs 8427  df-rdg 8466  df-1o 8522  df-2o 8523  df-er 8763  df-en 9004  df-dom 9005  df-sdom 9006  df-fin 9007  df-sup 9511  df-pnf 11326  df-mnf 11327  df-xr 11328  df-ltxr 11329  df-le 11330  df-sub 11522  df-neg 11523  df-div 11948  df-nn 12294  df-2 12356  df-3 12357  df-4 12358  df-5 12359  df-6 12360  df-7 12361  df-8 12362  df-9 12363  df-n0 12554  df-z 12640  df-dec 12759  df-uz 12904  df-rp 13058  df-fz 13568  df-seq 14053  df-exp 14113  df-cj 15148  df-re 15149  df-im 15150  df-sqrt 15284  df-abs 15285  df-dvds 16303  df-prm 16719  df-gz 16977  df-struct 17194  df-sets 17211  df-slot 17229  df-ndx 17241  df-base 17259  df-ress 17288  df-plusg 17324  df-mulr 17325  df-starv 17326  df-tset 17330  df-ple 17331  df-ds 17333  df-unif 17334  df-0g 17501  df-mgm 18678  df-sgrp 18757  df-mnd 18773  df-grp 18976  df-minusg 18977  df-subg 19163  df-cmn 19824  df-abl 19825  df-mgp 20162  df-rng 20180  df-ur 20209  df-ring 20262  df-cring 20263  df-oppr 20360  df-dvdsr 20383  df-unit 20384  df-irred 20385  df-invr 20414  df-dvr 20427  df-subrng 20572  df-subrg 20597  df-drng 20753  df-cnfld 21388  df-zring 21481
This theorem is referenced by:  dfprm2  21507  prmirred  21508
  Copyright terms: Public domain W3C validator