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

Theorem nnsub 9021
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 4033 . . . . . 6 (𝑥 = 1 → (𝑧 < 𝑥𝑧 < 1))
2 oveq1 5925 . . . . . . 7 (𝑥 = 1 → (𝑥𝑧) = (1 − 𝑧))
32eleq1d 2262 . . . . . 6 (𝑥 = 1 → ((𝑥𝑧) ∈ ℕ ↔ (1 − 𝑧) ∈ ℕ))
41, 3imbi12d 234 . . . . 5 (𝑥 = 1 → ((𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ (𝑧 < 1 → (1 − 𝑧) ∈ ℕ)))
54ralbidv 2494 . . . 4 (𝑥 = 1 → (∀𝑧 ∈ ℕ (𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ ∀𝑧 ∈ ℕ (𝑧 < 1 → (1 − 𝑧) ∈ ℕ)))
6 breq2 4033 . . . . . 6 (𝑥 = 𝑦 → (𝑧 < 𝑥𝑧 < 𝑦))
7 oveq1 5925 . . . . . . 7 (𝑥 = 𝑦 → (𝑥𝑧) = (𝑦𝑧))
87eleq1d 2262 . . . . . 6 (𝑥 = 𝑦 → ((𝑥𝑧) ∈ ℕ ↔ (𝑦𝑧) ∈ ℕ))
96, 8imbi12d 234 . . . . 5 (𝑥 = 𝑦 → ((𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ (𝑧 < 𝑦 → (𝑦𝑧) ∈ ℕ)))
109ralbidv 2494 . . . 4 (𝑥 = 𝑦 → (∀𝑧 ∈ ℕ (𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ ∀𝑧 ∈ ℕ (𝑧 < 𝑦 → (𝑦𝑧) ∈ ℕ)))
11 breq2 4033 . . . . . 6 (𝑥 = (𝑦 + 1) → (𝑧 < 𝑥𝑧 < (𝑦 + 1)))
12 oveq1 5925 . . . . . . 7 (𝑥 = (𝑦 + 1) → (𝑥𝑧) = ((𝑦 + 1) − 𝑧))
1312eleq1d 2262 . . . . . 6 (𝑥 = (𝑦 + 1) → ((𝑥𝑧) ∈ ℕ ↔ ((𝑦 + 1) − 𝑧) ∈ ℕ))
1411, 13imbi12d 234 . . . . 5 (𝑥 = (𝑦 + 1) → ((𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
1514ralbidv 2494 . . . 4 (𝑥 = (𝑦 + 1) → (∀𝑧 ∈ ℕ (𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ ∀𝑧 ∈ ℕ (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
16 breq2 4033 . . . . . 6 (𝑥 = 𝐵 → (𝑧 < 𝑥𝑧 < 𝐵))
17 oveq1 5925 . . . . . . 7 (𝑥 = 𝐵 → (𝑥𝑧) = (𝐵𝑧))
1817eleq1d 2262 . . . . . 6 (𝑥 = 𝐵 → ((𝑥𝑧) ∈ ℕ ↔ (𝐵𝑧) ∈ ℕ))
1916, 18imbi12d 234 . . . . 5 (𝑥 = 𝐵 → ((𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ (𝑧 < 𝐵 → (𝐵𝑧) ∈ ℕ)))
2019ralbidv 2494 . . . 4 (𝑥 = 𝐵 → (∀𝑧 ∈ ℕ (𝑧 < 𝑥 → (𝑥𝑧) ∈ ℕ) ↔ ∀𝑧 ∈ ℕ (𝑧 < 𝐵 → (𝐵𝑧) ∈ ℕ)))
21 nnnlt1 9008 . . . . . 6 (𝑧 ∈ ℕ → ¬ 𝑧 < 1)
2221pm2.21d 620 . . . . 5 (𝑧 ∈ ℕ → (𝑧 < 1 → (1 − 𝑧) ∈ ℕ))
2322rgen 2547 . . . 4 𝑧 ∈ ℕ (𝑧 < 1 → (1 − 𝑧) ∈ ℕ)
24 breq1 4032 . . . . . . 7 (𝑧 = 𝑥 → (𝑧 < 𝑦𝑥 < 𝑦))
25 oveq2 5926 . . . . . . . 8 (𝑧 = 𝑥 → (𝑦𝑧) = (𝑦𝑥))
2625eleq1d 2262 . . . . . . 7 (𝑧 = 𝑥 → ((𝑦𝑧) ∈ ℕ ↔ (𝑦𝑥) ∈ ℕ))
2724, 26imbi12d 234 . . . . . 6 (𝑧 = 𝑥 → ((𝑧 < 𝑦 → (𝑦𝑧) ∈ ℕ) ↔ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ)))
2827cbvralv 2726 . . . . 5 (∀𝑧 ∈ ℕ (𝑧 < 𝑦 → (𝑦𝑧) ∈ ℕ) ↔ ∀𝑥 ∈ ℕ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ))
29 nncn 8990 . . . . . . . . . . . . 13 (𝑦 ∈ ℕ → 𝑦 ∈ ℂ)
3029adantr 276 . . . . . . . . . . . 12 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → 𝑦 ∈ ℂ)
31 ax-1cn 7965 . . . . . . . . . . . 12 1 ∈ ℂ
32 pncan 8225 . . . . . . . . . . . 12 ((𝑦 ∈ ℂ ∧ 1 ∈ ℂ) → ((𝑦 + 1) − 1) = 𝑦)
3330, 31, 32sylancl 413 . . . . . . . . . . 11 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → ((𝑦 + 1) − 1) = 𝑦)
34 simpl 109 . . . . . . . . . . 11 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → 𝑦 ∈ ℕ)
3533, 34eqeltrd 2270 . . . . . . . . . 10 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → ((𝑦 + 1) − 1) ∈ ℕ)
36 oveq2 5926 . . . . . . . . . . 11 (𝑧 = 1 → ((𝑦 + 1) − 𝑧) = ((𝑦 + 1) − 1))
3736eleq1d 2262 . . . . . . . . . 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 4032 . . . . . . . . . 10 (𝑥 = (𝑧 − 1) → (𝑥 < 𝑦 ↔ (𝑧 − 1) < 𝑦))
42 oveq2 5926 . . . . . . . . . . 11 (𝑥 = (𝑧 − 1) → (𝑦𝑥) = (𝑦 − (𝑧 − 1)))
4342eleq1d 2262 . . . . . . . . . 10 (𝑥 = (𝑧 − 1) → ((𝑦𝑥) ∈ ℕ ↔ (𝑦 − (𝑧 − 1)) ∈ ℕ))
4441, 43imbi12d 234 . . . . . . . . 9 (𝑥 = (𝑧 − 1) → ((𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ) ↔ ((𝑧 − 1) < 𝑦 → (𝑦 − (𝑧 − 1)) ∈ ℕ)))
4544rspcv 2860 . . . . . . . 8 ((𝑧 − 1) ∈ ℕ → (∀𝑥 ∈ ℕ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ) → ((𝑧 − 1) < 𝑦 → (𝑦 − (𝑧 − 1)) ∈ ℕ)))
46 nnre 8989 . . . . . . . . . . 11 (𝑧 ∈ ℕ → 𝑧 ∈ ℝ)
47 nnre 8989 . . . . . . . . . . 11 (𝑦 ∈ ℕ → 𝑦 ∈ ℝ)
48 1re 8018 . . . . . . . . . . . 12 1 ∈ ℝ
49 ltsubadd 8451 . . . . . . . . . . . 12 ((𝑧 ∈ ℝ ∧ 1 ∈ ℝ ∧ 𝑦 ∈ ℝ) → ((𝑧 − 1) < 𝑦𝑧 < (𝑦 + 1)))
5048, 49mp3an2 1336 . . . . . . . . . . 11 ((𝑧 ∈ ℝ ∧ 𝑦 ∈ ℝ) → ((𝑧 − 1) < 𝑦𝑧 < (𝑦 + 1)))
5146, 47, 50syl2anr 290 . . . . . . . . . 10 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → ((𝑧 − 1) < 𝑦𝑧 < (𝑦 + 1)))
52 nncn 8990 . . . . . . . . . . . 12 (𝑧 ∈ ℕ → 𝑧 ∈ ℂ)
53 subsub3 8251 . . . . . . . . . . . . 13 ((𝑦 ∈ ℂ ∧ 𝑧 ∈ ℂ ∧ 1 ∈ ℂ) → (𝑦 − (𝑧 − 1)) = ((𝑦 + 1) − 𝑧))
5431, 53mp3an3 1337 . . . . . . . . . . . 12 ((𝑦 ∈ ℂ ∧ 𝑧 ∈ ℂ) → (𝑦 − (𝑧 − 1)) = ((𝑦 + 1) − 𝑧))
5529, 52, 54syl2an 289 . . . . . . . . . . 11 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (𝑦 − (𝑧 − 1)) = ((𝑦 + 1) − 𝑧))
5655eleq1d 2262 . . . . . . . . . 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 9000 . . . . . . . 8 (𝑧 ∈ ℕ → (𝑧 = 1 ∨ (𝑧 − 1) ∈ ℕ))
6160adantl 277 . . . . . . 7 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (𝑧 = 1 ∨ (𝑧 − 1) ∈ ℕ))
6240, 59, 61mpjaod 719 . . . . . 6 ((𝑦 ∈ ℕ ∧ 𝑧 ∈ ℕ) → (∀𝑥 ∈ ℕ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ) → (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
6362ralrimdva 2574 . . . . 5 (𝑦 ∈ ℕ → (∀𝑥 ∈ ℕ (𝑥 < 𝑦 → (𝑦𝑥) ∈ ℕ) → ∀𝑧 ∈ ℕ (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
6428, 63biimtrid 152 . . . 4 (𝑦 ∈ ℕ → (∀𝑧 ∈ ℕ (𝑧 < 𝑦 → (𝑦𝑧) ∈ ℕ) → ∀𝑧 ∈ ℕ (𝑧 < (𝑦 + 1) → ((𝑦 + 1) − 𝑧) ∈ ℕ)))
655, 10, 15, 20, 23, 64nnind 8998 . . 3 (𝐵 ∈ ℕ → ∀𝑧 ∈ ℕ (𝑧 < 𝐵 → (𝐵𝑧) ∈ ℕ))
66 breq1 4032 . . . . 5 (𝑧 = 𝐴 → (𝑧 < 𝐵𝐴 < 𝐵))
67 oveq2 5926 . . . . . 6 (𝑧 = 𝐴 → (𝐵𝑧) = (𝐵𝐴))
6867eleq1d 2262 . . . . 5 (𝑧 = 𝐴 → ((𝐵𝑧) ∈ ℕ ↔ (𝐵𝐴) ∈ ℕ))
6966, 68imbi12d 234 . . . 4 (𝑧 = 𝐴 → ((𝑧 < 𝐵 → (𝐵𝑧) ∈ ℕ) ↔ (𝐴 < 𝐵 → (𝐵𝐴) ∈ ℕ)))
7069rspcva 2862 . . 3 ((𝐴 ∈ ℕ ∧ ∀𝑧 ∈ ℕ (𝑧 < 𝐵 → (𝐵𝑧) ∈ ℕ)) → (𝐴 < 𝐵 → (𝐵𝐴) ∈ ℕ))
7165, 70sylan2 286 . 2 ((𝐴 ∈ ℕ ∧ 𝐵 ∈ ℕ) → (𝐴 < 𝐵 → (𝐵𝐴) ∈ ℕ))
72 nngt0 9007 . . 3 ((𝐵𝐴) ∈ ℕ → 0 < (𝐵𝐴))
73 nnre 8989 . . . 4 (𝐴 ∈ ℕ → 𝐴 ∈ ℝ)
74 nnre 8989 . . . 4 (𝐵 ∈ ℕ → 𝐵 ∈ ℝ)
75 posdif 8474 . . . 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 1364  wcel 2164  wral 2472   class class class wbr 4029  (class class class)co 5918  cc 7870  cr 7871  0cc0 7872  1c1 7873   + caddc 7875   < clt 8054  cmin 8190  cn 8982
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 1458  ax-7 1459  ax-gen 1460  ax-ie1 1504  ax-ie2 1505  ax-8 1515  ax-10 1516  ax-11 1517  ax-i12 1518  ax-bndl 1520  ax-4 1521  ax-17 1537  ax-i9 1541  ax-ial 1545  ax-i5r 1546  ax-13 2166  ax-14 2167  ax-ext 2175  ax-sep 4147  ax-pow 4203  ax-pr 4238  ax-un 4464  ax-setind 4569  ax-cnex 7963  ax-resscn 7964  ax-1cn 7965  ax-1re 7966  ax-icn 7967  ax-addcl 7968  ax-addrcl 7969  ax-mulcl 7970  ax-addcom 7972  ax-addass 7974  ax-distr 7976  ax-i2m1 7977  ax-0lt1 7978  ax-0id 7980  ax-rnegex 7981  ax-cnre 7983  ax-pre-ltirr 7984  ax-pre-ltwlin 7985  ax-pre-lttrn 7986  ax-pre-ltadd 7988
This theorem depends on definitions:  df-bi 117  df-3an 982  df-tru 1367  df-fal 1370  df-nf 1472  df-sb 1774  df-eu 2045  df-mo 2046  df-clab 2180  df-cleq 2186  df-clel 2189  df-nfc 2325  df-ne 2365  df-nel 2460  df-ral 2477  df-rex 2478  df-reu 2479  df-rab 2481  df-v 2762  df-sbc 2986  df-dif 3155  df-un 3157  df-in 3159  df-ss 3166  df-pw 3603  df-sn 3624  df-pr 3625  df-op 3627  df-uni 3836  df-int 3871  df-br 4030  df-opab 4091  df-id 4324  df-xp 4665  df-rel 4666  df-cnv 4667  df-co 4668  df-dm 4669  df-iota 5215  df-fun 5256  df-fv 5262  df-riota 5873  df-ov 5921  df-oprab 5922  df-mpo 5923  df-pnf 8056  df-mnf 8057  df-xr 8058  df-ltxr 8059  df-le 8060  df-sub 8192  df-neg 8193  df-inn 8983
This theorem is referenced by:  nnsubi  9022  uz3m2nn  9638  pythagtriplem13  12414
  Copyright terms: Public domain W3C validator