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

Theorem nnsub 9074
Description: Subtraction of positive integers. (Contributed by NM, 20-Aug-2001.) (Revised by Mario Carneiro, 16-May-2014.)
Assertion
Ref Expression
nnsub ((𝐴 ∈ ℕ ∧ 𝐵 ∈ ℕ) → (𝐴 < 𝐵 ↔ (𝐵𝐴) ∈ ℕ))

Proof of Theorem nnsub
Dummy variables 𝑧 𝑥 𝑦 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 breq2 4047 . . . . . 6 (𝑥 = 1 → (𝑧 < 𝑥𝑧 < 1))
2 oveq1 5950 . . . . . . 7 (𝑥 = 1 → (𝑥𝑧) = (1 − 𝑧))
32eleq1d 2273 . . . . . 6 (𝑥 = 1 → ((𝑥𝑧) ∈ ℕ ↔ (1 − 𝑧) ∈ ℕ))
41, 3imbi12d 234 . . . . 5 (𝑥 = 1 → ((𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ (𝑧 < 1 → (1 − 𝑧) ∈ ℕ)))
54ralbidv 2505 . . . 4 (𝑥 = 1 → (∀𝑧 ∈ ℕ (𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ ∀𝑧 ∈ ℕ (𝑧 < 1 → (1 − 𝑧) ∈ ℕ)))
6 breq2 4047 . . . . . 6 (𝑥 = 𝑦 → (𝑧 < 𝑥𝑧 < 𝑦))
7 oveq1 5950 . . . . . . 7 (𝑥 = 𝑦 → (𝑥𝑧) = (𝑦𝑧))
87eleq1d 2273 . . . . . 6 (𝑥 = 𝑦 → ((𝑥𝑧) ∈ ℕ ↔ (𝑦𝑧) ∈ ℕ))
96, 8imbi12d 234 . . . . 5 (𝑥 = 𝑦 → ((𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ (𝑧 < 𝑦 → (𝑦𝑧) ∈ ℕ)))
109ralbidv 2505 . . . 4 (𝑥 = 𝑦 → (∀𝑧 ∈ ℕ (𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ ∀𝑧 ∈ ℕ (𝑧 < 𝑦 → (𝑦𝑧) ∈ ℕ)))
11 breq2 4047 . . . . . 6 (𝑥 = (𝑦 + 1) → (𝑧 < 𝑥𝑧 < (𝑦 + 1)))
12 oveq1 5950 . . . . . . 7 (𝑥 = (𝑦 + 1) → (𝑥𝑧) = ((𝑦 + 1) − 𝑧))
1312eleq1d 2273 . . . . . 6 (𝑥 = (𝑦 + 1) → ((𝑥𝑧) ∈ ℕ ↔ ((𝑦 + 1) − 𝑧) ∈ ℕ))
1411, 13imbi12d 234 . . . . 5 (𝑥 = (𝑦 + 1) → ((𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
1514ralbidv 2505 . . . 4 (𝑥 = (𝑦 + 1) → (∀𝑧 ∈ ℕ (𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ ∀𝑧 ∈ ℕ (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
16 breq2 4047 . . . . . 6 (𝑥 = 𝐵 → (𝑧 < 𝑥𝑧 < 𝐵))
17 oveq1 5950 . . . . . . 7 (𝑥 = 𝐵 → (𝑥𝑧) = (𝐵𝑧))
1817eleq1d 2273 . . . . . 6 (𝑥 = 𝐵 → ((𝑥𝑧) ∈ ℕ ↔ (𝐵𝑧) ∈ ℕ))
1916, 18imbi12d 234 . . . . 5 (𝑥 = 𝐵 → ((𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ (𝑧 < 𝐵 → (𝐵𝑧) ∈ ℕ)))
2019ralbidv 2505 . . . 4 (𝑥 = 𝐵 → (∀𝑧 ∈ ℕ (𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ ∀𝑧 ∈ ℕ (𝑧 < 𝐵 → (𝐵𝑧) ∈ ℕ)))
21 nnnlt1 9061 . . . . . 6 (𝑧 ∈ ℕ → ¬ 𝑧 < 1)
2221pm2.21d 620 . . . . 5 (𝑧 ∈ ℕ → (𝑧 < 1 → (1 − 𝑧) ∈ ℕ))
2322rgen 2558 . . . 4 𝑧 ∈ ℕ (𝑧 < 1 → (1 − 𝑧) ∈ ℕ)
24 breq1 4046 . . . . . . 7 (𝑧 = 𝑥 → (𝑧 < 𝑦𝑥 < 𝑦))
25 oveq2 5951 . . . . . . . 8 (𝑧 = 𝑥 → (𝑦𝑧) = (𝑦𝑥))
2625eleq1d 2273 . . . . . . 7 (𝑧 = 𝑥 → ((𝑦𝑧) ∈ ℕ ↔ (𝑦𝑥) ∈ ℕ))
2724, 26imbi12d 234 . . . . . 6 (𝑧 = 𝑥 → ((𝑧 < 𝑦 → (𝑦𝑧) ∈ ℕ) ↔ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ)))
2827cbvralv 2737 . . . . 5 (∀𝑧 ∈ ℕ (𝑧 < 𝑦 → (𝑦𝑧) ∈ ℕ) ↔ ∀𝑥 ∈ ℕ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ))
29 nncn 9043 . . . . . . . . . . . . 13 (𝑦 ∈ ℕ → 𝑦 ∈ ℂ)
3029adantr 276 . . . . . . . . . . . 12 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → 𝑦 ∈ ℂ)
31 ax-1cn 8017 . . . . . . . . . . . 12 1 ∈ ℂ
32 pncan 8277 . . . . . . . . . . . 12 ((𝑦 ∈ ℂ ∧ 1 ∈ ℂ) → ((𝑦 + 1) − 1) = 𝑦)
3330, 31, 32sylancl 413 . . . . . . . . . . 11 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → ((𝑦 + 1) − 1) = 𝑦)
34 simpl 109 . . . . . . . . . . 11 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → 𝑦 ∈ ℕ)
3533, 34eqeltrd 2281 . . . . . . . . . 10 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → ((𝑦 + 1) − 1) ∈ ℕ)
36 oveq2 5951 . . . . . . . . . . 11 (𝑧 = 1 → ((𝑦 + 1) − 𝑧) = ((𝑦 + 1) − 1))
3736eleq1d 2273 . . . . . . . . . 10 (𝑧 = 1 → (((𝑦 + 1) − 𝑧) ∈ ℕ ↔ ((𝑦 + 1) − 1) ∈ ℕ))
3835, 37syl5ibrcom 157 . . . . . . . . 9 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (𝑧 = 1 → ((𝑦 + 1) − 𝑧) ∈ ℕ))
3938a1dd 48 . . . . . . . 8 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (𝑧 = 1 → (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
4039a1dd 48 . . . . . . 7 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (𝑧 = 1 → (∀𝑥 ∈ ℕ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ) → (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ))))
41 breq1 4046 . . . . . . . . . 10 (𝑥 = (𝑧 − 1) → (𝑥 < 𝑦 ↔ (𝑧 − 1) < 𝑦))
42 oveq2 5951 . . . . . . . . . . 11 (𝑥 = (𝑧 − 1) → (𝑦𝑥) = (𝑦 − (𝑧 − 1)))
4342eleq1d 2273 . . . . . . . . . 10 (𝑥 = (𝑧 − 1) → ((𝑦𝑥) ∈ ℕ ↔ (𝑦 − (𝑧 − 1)) ∈ ℕ))
4441, 43imbi12d 234 . . . . . . . . 9 (𝑥 = (𝑧 − 1) → ((𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ) ↔ ((𝑧 − 1) < 𝑦 → (𝑦 − (𝑧 − 1)) ∈ ℕ)))
4544rspcv 2872 . . . . . . . 8 ((𝑧 − 1) ∈ ℕ → (∀𝑥 ∈ ℕ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ) → ((𝑧 − 1) < 𝑦 → (𝑦 − (𝑧 − 1)) ∈ ℕ)))
46 nnre 9042 . . . . . . . . . . 11 (𝑧 ∈ ℕ → 𝑧 ∈ ℝ)
47 nnre 9042 . . . . . . . . . . 11 (𝑦 ∈ ℕ → 𝑦 ∈ ℝ)
48 1re 8070 . . . . . . . . . . . 12 1 ∈ ℝ
49 ltsubadd 8504 . . . . . . . . . . . 12 ((𝑧 ∈ ℝ ∧ 1 ∈ ℝ ∧ 𝑦 ∈ ℝ) → ((𝑧 − 1) < 𝑦𝑧 < (𝑦 + 1)))
5048, 49mp3an2 1337 . . . . . . . . . . 11 ((𝑧 ∈ ℝ ∧ 𝑦 ∈ ℝ) → ((𝑧 − 1) < 𝑦𝑧 < (𝑦 + 1)))
5146, 47, 50syl2anr 290 . . . . . . . . . 10 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → ((𝑧 − 1) < 𝑦𝑧 < (𝑦 + 1)))
52 nncn 9043 . . . . . . . . . . . 12 (𝑧 ∈ ℕ → 𝑧 ∈ ℂ)
53 subsub3 8303 . . . . . . . . . . . . 13 ((𝑦 ∈ ℂ ∧ 𝑧 ∈ ℂ ∧ 1 ∈ ℂ) → (𝑦 − (𝑧 − 1)) = ((𝑦 + 1) − 𝑧))
5431, 53mp3an3 1338 . . . . . . . . . . . 12 ((𝑦 ∈ ℂ ∧ 𝑧 ∈ ℂ) → (𝑦 − (𝑧 − 1)) = ((𝑦 + 1) − 𝑧))
5529, 52, 54syl2an 289 . . . . . . . . . . 11 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (𝑦 − (𝑧 − 1)) = ((𝑦 + 1) − 𝑧))
5655eleq1d 2273 . . . . . . . . . 10 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → ((𝑦 − (𝑧 − 1)) ∈ ℕ ↔ ((𝑦 + 1) − 𝑧) ∈ ℕ))
5751, 56imbi12d 234 . . . . . . . . 9 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (((𝑧 − 1) < 𝑦 → (𝑦 − (𝑧 − 1)) ∈ ℕ) ↔ (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
5857biimpd 144 . . . . . . . 8 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (((𝑧 − 1) < 𝑦 → (𝑦 − (𝑧 − 1)) ∈ ℕ) → (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
5945, 58syl9r 73 . . . . . . 7 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → ((𝑧 − 1) ∈ ℕ → (∀𝑥 ∈ ℕ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ) → (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ))))
60 nn1m1nn 9053 . . . . . . . 8 (𝑧 ∈ ℕ → (𝑧 = 1 ∨ (𝑧 − 1) ∈ ℕ))
6160adantl 277 . . . . . . 7 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (𝑧 = 1 ∨ (𝑧 − 1) ∈ ℕ))
6240, 59, 61mpjaod 719 . . . . . 6 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (∀𝑥 ∈ ℕ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ) → (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
6362ralrimdva 2585 . . . . 5 (𝑦 ∈ ℕ → (∀𝑥 ∈ ℕ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ) → ∀𝑧 ∈ ℕ (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
6428, 63biimtrid 152 . . . 4 (𝑦 ∈ ℕ → (∀𝑧 ∈ ℕ (𝑧 < 𝑦 → (𝑦𝑧) ∈ ℕ) → ∀𝑧 ∈ ℕ (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
655, 10, 15, 20, 23, 64nnind 9051 . . 3 (𝐵 ∈ ℕ → ∀𝑧 ∈ ℕ (𝑧 < 𝐵 → (𝐵𝑧) ∈ ℕ))
66 breq1 4046 . . . . 5 (𝑧 = 𝐴 → (𝑧 < 𝐵𝐴 < 𝐵))
67 oveq2 5951 . . . . . 6 (𝑧 = 𝐴 → (𝐵𝑧) = (𝐵𝐴))
6867eleq1d 2273 . . . . 5 (𝑧 = 𝐴 → ((𝐵𝑧) ∈ ℕ ↔ (𝐵𝐴) ∈ ℕ))
6966, 68imbi12d 234 . . . 4 (𝑧 = 𝐴 → ((𝑧 < 𝐵 → (𝐵𝑧) ∈ ℕ) ↔ (𝐴 < 𝐵 → (𝐵𝐴) ∈ ℕ)))
7069rspcva 2874 . . 3 ((𝐴 ∈ ℕ ∧ ∀𝑧 ∈ ℕ (𝑧 < 𝐵 → (𝐵𝑧) ∈ ℕ)) → (𝐴 < 𝐵 → (𝐵𝐴) ∈ ℕ))
7165, 70sylan2 286 . 2 ((𝐴 ∈ ℕ ∧ 𝐵 ∈ ℕ) → (𝐴 < 𝐵 → (𝐵𝐴) ∈ ℕ))
72 nngt0 9060 . . 3 ((𝐵𝐴) ∈ ℕ → 0 < (𝐵𝐴))
73 nnre 9042 . . . 4 (𝐴 ∈ ℕ → 𝐴 ∈ ℝ)
74 nnre 9042 . . . 4 (𝐵 ∈ ℕ → 𝐵 ∈ ℝ)
75 posdif 8527 . . . 4 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) → (𝐴 < 𝐵 ↔ 0 < (𝐵𝐴)))
7673, 74, 75syl2an 289 . . 3 ((𝐴 ∈ ℕ ∧ 𝐵 ∈ ℕ) → (𝐴 < 𝐵 ↔ 0 < (𝐵𝐴)))
7772, 76imbitrrid 156 . 2 ((𝐴 ∈ ℕ ∧ 𝐵 ∈ ℕ) → ((𝐵𝐴) ∈ ℕ → 𝐴 < 𝐵))
7871, 77impbid 129 1 ((𝐴 ∈ ℕ ∧ 𝐵 ∈ ℕ) → (𝐴 < 𝐵 ↔ (𝐵𝐴) ∈ ℕ))
Colors of variables: wff set class
Syntax hints:  wi 4  wa 104  wb 105  wo 709   = wceq 1372  wcel 2175  wral 2483   class class class wbr 4043  (class class class)co 5943  cc 7922  cr 7923  0cc0 7924  1c1 7925   + caddc 7927   < clt 8106  cmin 8242  cn 9035
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 615  ax-in2 616  ax-io 710  ax-5 1469  ax-7 1470  ax-gen 1471  ax-ie1 1515  ax-ie2 1516  ax-8 1526  ax-10 1527  ax-11 1528  ax-i12 1529  ax-bndl 1531  ax-4 1532  ax-17 1548  ax-i9 1552  ax-ial 1556  ax-i5r 1557  ax-13 2177  ax-14 2178  ax-ext 2186  ax-sep 4161  ax-pow 4217  ax-pr 4252  ax-un 4479  ax-setind 4584  ax-cnex 8015  ax-resscn 8016  ax-1cn 8017  ax-1re 8018  ax-icn 8019  ax-addcl 8020  ax-addrcl 8021  ax-mulcl 8022  ax-addcom 8024  ax-addass 8026  ax-distr 8028  ax-i2m1 8029  ax-0lt1 8030  ax-0id 8032  ax-rnegex 8033  ax-cnre 8035  ax-pre-ltirr 8036  ax-pre-ltwlin 8037  ax-pre-lttrn 8038  ax-pre-ltadd 8040
This theorem depends on definitions:  df-bi 117  df-3an 982  df-tru 1375  df-fal 1378  df-nf 1483  df-sb 1785  df-eu 2056  df-mo 2057  df-clab 2191  df-cleq 2197  df-clel 2200  df-nfc 2336  df-ne 2376  df-nel 2471  df-ral 2488  df-rex 2489  df-reu 2490  df-rab 2492  df-v 2773  df-sbc 2998  df-dif 3167  df-un 3169  df-in 3171  df-ss 3178  df-pw 3617  df-sn 3638  df-pr 3639  df-op 3641  df-uni 3850  df-int 3885  df-br 4044  df-opab 4105  df-id 4339  df-xp 4680  df-rel 4681  df-cnv 4682  df-co 4683  df-dm 4684  df-iota 5231  df-fun 5272  df-fv 5278  df-riota 5898  df-ov 5946  df-oprab 5947  df-mpo 5948  df-pnf 8108  df-mnf 8109  df-xr 8110  df-ltxr 8111  df-le 8112  df-sub 8244  df-neg 8245  df-inn 9036
This theorem is referenced by:  nnsubi  9075  uz3m2nn  9693  pythagtriplem13  12541  perfectlem1  15413
  Copyright terms: Public domain W3C validator