ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  qreccl GIF version

Theorem qreccl 9825
Description: Closure of reciprocal of rationals. (Contributed by NM, 3-Aug-2004.)
Assertion
Ref Expression
qreccl ((𝐴 ∈ ℚ ∧ 𝐴 ≠ 0) → (1 / 𝐴) ∈ ℚ)

Proof of Theorem qreccl
Dummy variables 𝑥 𝑦 𝑧 𝑤 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 ax-1cn 8080 . . . . . 6 1 ∈ ℂ
2 1ap0 8725 . . . . . 6 1 # 0
31, 2div0api 8881 . . . . 5 (0 / 1) = 0
4 0z 9445 . . . . . 6 0 ∈ ℤ
5 1nn 9109 . . . . . 6 1 ∈ ℕ
6 znq 9807 . . . . . 6 ((0 ∈ ℤ ∧ 1 ∈ ℕ) → (0 / 1) ∈ ℚ)
74, 5, 6mp2an 426 . . . . 5 (0 / 1) ∈ ℚ
83, 7eqeltrri 2303 . . . 4 0 ∈ ℚ
9 qapne 9822 . . . 4 ((𝐴 ∈ ℚ ∧ 0 ∈ ℚ) → (𝐴 # 0 ↔ 𝐴 ≠ 0))
108, 9mpan2 425 . . 3 (𝐴 ∈ ℚ → (𝐴 # 0 ↔ 𝐴 ≠ 0))
1110biimpar 297 . 2 ((𝐴 ∈ ℚ ∧ 𝐴 ≠ 0) → 𝐴 # 0)
12 elq 9805 . . . 4 (𝐴 ∈ ℚ ↔ ∃𝑥 ∈ ℤ ∃𝑦 ∈ ℕ 𝐴 = (𝑥 / 𝑦))
13 nnne0 9126 . . . . . . . 8 (𝑦 ∈ ℕ → 𝑦 ≠ 0)
1413ancli 323 . . . . . . 7 (𝑦 ∈ ℕ → (𝑦 ∈ ℕ ∧ 𝑦 ≠ 0))
15 nnz 9453 . . . . . . . . . . . . . . . 16 (𝑦 ∈ ℕ → 𝑦 ∈ ℤ)
16 zapne 9509 . . . . . . . . . . . . . . . 16 ((𝑦 ∈ ℤ ∧ 0 ∈ ℤ) → (𝑦 # 0 ↔ 𝑦 ≠ 0))
1715, 4, 16sylancl 413 . . . . . . . . . . . . . . 15 (𝑦 ∈ ℕ → (𝑦 # 0 ↔ 𝑦 ≠ 0))
1817adantl 277 . . . . . . . . . . . . . 14 ((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) → (𝑦 # 0 ↔ 𝑦 ≠ 0))
1918pm5.32i 454 . . . . . . . . . . . . 13 (((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 # 0) ↔ ((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0))
2019anbi1i 458 . . . . . . . . . . . 12 ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 # 0) ∧ 𝐴 = (𝑥 / 𝑦)) ↔ (((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)))
21 breq1 4085 . . . . . . . . . . . . 13 (𝐴 = (𝑥 / 𝑦) → (𝐴 # 0 ↔ (𝑥 / 𝑦) # 0))
22 zcn 9439 . . . . . . . . . . . . . . . 16 (𝑥 ∈ ℤ → 𝑥 ∈ ℂ)
23 nncn 9106 . . . . . . . . . . . . . . . 16 (𝑦 ∈ ℕ → 𝑦 ∈ ℂ)
2422, 23anim12i 338 . . . . . . . . . . . . . . 15 ((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) → (𝑥 ∈ ℂ ∧ 𝑦 ∈ ℂ))
25 divap0b 8818 . . . . . . . . . . . . . . . 16 ((𝑥 ∈ ℂ ∧ 𝑦 ∈ ℂ ∧ 𝑦 # 0) → (𝑥 # 0 ↔ (𝑥 / 𝑦) # 0))
26253expa 1227 . . . . . . . . . . . . . . 15 (((𝑥 ∈ ℂ ∧ 𝑦 ∈ ℂ) ∧ 𝑦 # 0) → (𝑥 # 0 ↔ (𝑥 / 𝑦) # 0))
2724, 26sylan 283 . . . . . . . . . . . . . 14 (((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 # 0) → (𝑥 # 0 ↔ (𝑥 / 𝑦) # 0))
2827bicomd 141 . . . . . . . . . . . . 13 (((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 # 0) → ((𝑥 / 𝑦) # 0 ↔ 𝑥 # 0))
2921, 28sylan9bbr 463 . . . . . . . . . . . 12 ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 # 0) ∧ 𝐴 = (𝑥 / 𝑦)) → (𝐴 # 0 ↔ 𝑥 # 0))
3020, 29sylbir 135 . . . . . . . . . . 11 ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) → (𝐴 # 0 ↔ 𝑥 # 0))
31 simplll 533 . . . . . . . . . . . 12 ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) → 𝑥 ∈ ℤ)
32 zapne 9509 . . . . . . . . . . . 12 ((𝑥 ∈ ℤ ∧ 0 ∈ ℤ) → (𝑥 # 0 ↔ 𝑥 ≠ 0))
3331, 4, 32sylancl 413 . . . . . . . . . . 11 ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) → (𝑥 # 0 ↔ 𝑥 ≠ 0))
3430, 33bitrd 188 . . . . . . . . . 10 ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) → (𝐴 # 0 ↔ 𝑥 ≠ 0))
35 zmulcl 9488 . . . . . . . . . . . . . . . . 17 ((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℤ) → (𝑥 · 𝑦) ∈ ℤ)
3615, 35sylan2 286 . . . . . . . . . . . . . . . 16 ((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) → (𝑥 · 𝑦) ∈ ℤ)
3736adantr 276 . . . . . . . . . . . . . . 15 (((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑥 ≠ 0) → (𝑥 · 𝑦) ∈ ℤ)
38 msqznn 9535 . . . . . . . . . . . . . . . 16 ((𝑥 ∈ ℤ ∧ 𝑥 ≠ 0) → (𝑥 · 𝑥) ∈ ℕ)
3938adantlr 477 . . . . . . . . . . . . . . 15 (((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑥 ≠ 0) → (𝑥 · 𝑥) ∈ ℕ)
4037, 39jca 306 . . . . . . . . . . . . . 14 (((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑥 ≠ 0) → ((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ))
4140adantlr 477 . . . . . . . . . . . . 13 ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝑥 ≠ 0) → ((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ))
4241adantlr 477 . . . . . . . . . . . 12 (((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) ∧ 𝑥 ≠ 0) → ((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ))
4320anbi1i 458 . . . . . . . . . . . . . 14 (((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 # 0) ∧ 𝐴 = (𝑥 / 𝑦)) ∧ 𝑥 # 0) ↔ ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) ∧ 𝑥 # 0))
4433pm5.32i 454 . . . . . . . . . . . . . 14 (((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) ∧ 𝑥 # 0) ↔ ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) ∧ 𝑥 ≠ 0))
4543, 44bitri 184 . . . . . . . . . . . . 13 (((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 # 0) ∧ 𝐴 = (𝑥 / 𝑦)) ∧ 𝑥 # 0) ↔ ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) ∧ 𝑥 ≠ 0))
46 oveq2 6002 . . . . . . . . . . . . . . 15 (𝐴 = (𝑥 / 𝑦) → (1 / 𝐴) = (1 / (𝑥 / 𝑦)))
47 dividap 8836 . . . . . . . . . . . . . . . . . . . . 21 ((𝑥 ∈ ℂ ∧ 𝑥 # 0) → (𝑥 / 𝑥) = 1)
4847adantr 276 . . . . . . . . . . . . . . . . . . . 20 (((𝑥 ∈ ℂ ∧ 𝑥 # 0) ∧ (𝑦 ∈ ℂ ∧ 𝑦 # 0)) → (𝑥 / 𝑥) = 1)
4948oveq1d 6009 . . . . . . . . . . . . . . . . . . 19 (((𝑥 ∈ ℂ ∧ 𝑥 # 0) ∧ (𝑦 ∈ ℂ ∧ 𝑦 # 0)) → ((𝑥 / 𝑥) / (𝑥 / 𝑦)) = (1 / (𝑥 / 𝑦)))
50 simpll 527 . . . . . . . . . . . . . . . . . . . 20 (((𝑥 ∈ ℂ ∧ 𝑥 # 0) ∧ (𝑦 ∈ ℂ ∧ 𝑦 # 0)) → 𝑥 ∈ ℂ)
51 simpl 109 . . . . . . . . . . . . . . . . . . . 20 (((𝑥 ∈ ℂ ∧ 𝑥 # 0) ∧ (𝑦 ∈ ℂ ∧ 𝑦 # 0)) → (𝑥 ∈ ℂ ∧ 𝑥 # 0))
52 simpr 110 . . . . . . . . . . . . . . . . . . . 20 (((𝑥 ∈ ℂ ∧ 𝑥 # 0) ∧ (𝑦 ∈ ℂ ∧ 𝑦 # 0)) → (𝑦 ∈ ℂ ∧ 𝑦 # 0))
53 divdivdivap 8848 . . . . . . . . . . . . . . . . . . . 20 (((𝑥 ∈ ℂ ∧ (𝑥 ∈ ℂ ∧ 𝑥 # 0)) ∧ ((𝑥 ∈ ℂ ∧ 𝑥 # 0) ∧ (𝑦 ∈ ℂ ∧ 𝑦 # 0))) → ((𝑥 / 𝑥) / (𝑥 / 𝑦)) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))
5450, 51, 51, 52, 53syl22anc 1272 . . . . . . . . . . . . . . . . . . 19 (((𝑥 ∈ ℂ ∧ 𝑥 # 0) ∧ (𝑦 ∈ ℂ ∧ 𝑦 # 0)) → ((𝑥 / 𝑥) / (𝑥 / 𝑦)) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))
5549, 54eqtr3d 2264 . . . . . . . . . . . . . . . . . 18 (((𝑥 ∈ ℂ ∧ 𝑥 # 0) ∧ (𝑦 ∈ ℂ ∧ 𝑦 # 0)) → (1 / (𝑥 / 𝑦)) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))
5655an4s 590 . . . . . . . . . . . . . . . . 17 (((𝑥 ∈ ℂ ∧ 𝑦 ∈ ℂ) ∧ (𝑥 # 0 ∧ 𝑦 # 0)) → (1 / (𝑥 / 𝑦)) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))
5724, 56sylan 283 . . . . . . . . . . . . . . . 16 (((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ (𝑥 # 0 ∧ 𝑦 # 0)) → (1 / (𝑥 / 𝑦)) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))
5857anass1rs 571 . . . . . . . . . . . . . . 15 ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 # 0) ∧ 𝑥 # 0) → (1 / (𝑥 / 𝑦)) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))
5946, 58sylan9eqr 2284 . . . . . . . . . . . . . 14 (((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 # 0) ∧ 𝑥 # 0) ∧ 𝐴 = (𝑥 / 𝑦)) → (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))
6059an32s 568 . . . . . . . . . . . . 13 (((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 # 0) ∧ 𝐴 = (𝑥 / 𝑦)) ∧ 𝑥 # 0) → (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))
6145, 60sylbir 135 . . . . . . . . . . . 12 (((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) ∧ 𝑥 ≠ 0) → (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))
6242, 61jca 306 . . . . . . . . . . 11 (((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) ∧ 𝑥 ≠ 0) → (((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ) ∧ (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥))))
6362ex 115 . . . . . . . . . 10 ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) → (𝑥 ≠ 0 → (((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ) ∧ (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))))
6434, 63sylbid 150 . . . . . . . . 9 ((((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) ∧ 𝐴 = (𝑥 / 𝑦)) → (𝐴 # 0 → (((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ) ∧ (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥)))))
6564ex 115 . . . . . . . 8 (((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) ∧ 𝑦 ≠ 0) → (𝐴 = (𝑥 / 𝑦) → (𝐴 # 0 → (((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ) ∧ (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥))))))
6665anasss 399 . . . . . . 7 ((𝑥 ∈ ℤ ∧ (𝑦 ∈ ℕ ∧ 𝑦 ≠ 0)) → (𝐴 = (𝑥 / 𝑦) → (𝐴 # 0 → (((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ) ∧ (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥))))))
6714, 66sylan2 286 . . . . . 6 ((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) → (𝐴 = (𝑥 / 𝑦) → (𝐴 # 0 → (((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ) ∧ (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥))))))
68 rspceov 6037 . . . . . . . 8 (((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ ∧ (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥))) → ∃𝑧 ∈ ℤ ∃𝑤 ∈ ℕ (1 / 𝐴) = (𝑧 / 𝑤))
69683expa 1227 . . . . . . 7 ((((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ) ∧ (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥))) → ∃𝑧 ∈ ℤ ∃𝑤 ∈ ℕ (1 / 𝐴) = (𝑧 / 𝑤))
70 elq 9805 . . . . . . 7 ((1 / 𝐴) ∈ ℚ ↔ ∃𝑧 ∈ ℤ ∃𝑤 ∈ ℕ (1 / 𝐴) = (𝑧 / 𝑤))
7169, 70sylibr 134 . . . . . 6 ((((𝑥 · 𝑦) ∈ ℤ ∧ (𝑥 · 𝑥) ∈ ℕ) ∧ (1 / 𝐴) = ((𝑥 · 𝑦) / (𝑥 · 𝑥))) → (1 / 𝐴) ∈ ℚ)
7267, 71syl8 71 . . . . 5 ((𝑥 ∈ ℤ ∧ 𝑦 ∈ ℕ) → (𝐴 = (𝑥 / 𝑦) → (𝐴 # 0 → (1 / 𝐴) ∈ ℚ)))
7372rexlimivv 2654 . . . 4 (∃𝑥 ∈ ℤ ∃𝑦 ∈ ℕ 𝐴 = (𝑥 / 𝑦) → (𝐴 # 0 → (1 / 𝐴) ∈ ℚ))
7412, 73sylbi 121 . . 3 (𝐴 ∈ ℚ → (𝐴 # 0 → (1 / 𝐴) ∈ ℚ))
7574imp 124 . 2 ((𝐴 ∈ ℚ ∧ 𝐴 # 0) → (1 / 𝐴) ∈ ℚ)
7611, 75syldan 282 1 ((𝐴 ∈ ℚ ∧ 𝐴 ≠ 0) → (1 / 𝐴) ∈ ℚ)
Colors of variables: wff set class
Syntax hints:  wi 4  wa 104  wb 105   = wceq 1395  wcel 2200  wne 2400  wrex 2509   class class class wbr 4082  (class class class)co 5994  cc 7985  0cc0 7987  1c1 7988   · cmul 7992   # cap 8716   / cdiv 8807  cn 9098  cz 9434  cq 9802
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 106  ax-ia2 107  ax-ia3 108  ax-in1 617  ax-in2 618  ax-io 714  ax-5 1493  ax-7 1494  ax-gen 1495  ax-ie1 1539  ax-ie2 1540  ax-8 1550  ax-10 1551  ax-11 1552  ax-i12 1553  ax-bndl 1555  ax-4 1556  ax-17 1572  ax-i9 1576  ax-ial 1580  ax-i5r 1581  ax-13 2202  ax-14 2203  ax-ext 2211  ax-sep 4201  ax-pow 4257  ax-pr 4292  ax-un 4521  ax-setind 4626  ax-cnex 8078  ax-resscn 8079  ax-1cn 8080  ax-1re 8081  ax-icn 8082  ax-addcl 8083  ax-addrcl 8084  ax-mulcl 8085  ax-mulrcl 8086  ax-addcom 8087  ax-mulcom 8088  ax-addass 8089  ax-mulass 8090  ax-distr 8091  ax-i2m1 8092  ax-0lt1 8093  ax-1rid 8094  ax-0id 8095  ax-rnegex 8096  ax-precex 8097  ax-cnre 8098  ax-pre-ltirr 8099  ax-pre-ltwlin 8100  ax-pre-lttrn 8101  ax-pre-apti 8102  ax-pre-ltadd 8103  ax-pre-mulgt0 8104  ax-pre-mulext 8105
This theorem depends on definitions:  df-bi 117  df-3or 1003  df-3an 1004  df-tru 1398  df-fal 1401  df-nf 1507  df-sb 1809  df-eu 2080  df-mo 2081  df-clab 2216  df-cleq 2222  df-clel 2225  df-nfc 2361  df-ne 2401  df-nel 2496  df-ral 2513  df-rex 2514  df-reu 2515  df-rmo 2516  df-rab 2517  df-v 2801  df-sbc 3029  df-csb 3125  df-dif 3199  df-un 3201  df-in 3203  df-ss 3210  df-pw 3651  df-sn 3672  df-pr 3673  df-op 3675  df-uni 3888  df-int 3923  df-iun 3966  df-br 4083  df-opab 4145  df-mpt 4146  df-id 4381  df-po 4384  df-iso 4385  df-xp 4722  df-rel 4723  df-cnv 4724  df-co 4725  df-dm 4726  df-rn 4727  df-res 4728  df-ima 4729  df-iota 5274  df-fun 5316  df-fn 5317  df-f 5318  df-fv 5322  df-riota 5947  df-ov 5997  df-oprab 5998  df-mpo 5999  df-1st 6276  df-2nd 6277  df-pnf 8171  df-mnf 8172  df-xr 8173  df-ltxr 8174  df-le 8175  df-sub 8307  df-neg 8308  df-reap 8710  df-ap 8717  df-div 8808  df-inn 9099  df-n0 9358  df-z 9435  df-q 9803
This theorem is referenced by:  qdivcl  9826  qexpclz  10769
  Copyright terms: Public domain W3C validator