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

Theorem modge0 13803
Description: The modulo operation is nonnegative. (Contributed by NM, 10-Nov-2008.)
Assertion
Ref Expression
modge0 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → 0 ≤ (𝐴 mod 𝐵))

Proof of Theorem modge0
StepHypRef Expression
1 fldivle 13755 . . . 4 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → (⌊‘(𝐴 / 𝐵)) ≤ (𝐴 / 𝐵))
2 refldivcl 13747 . . . . 5 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → (⌊‘(𝐴 / 𝐵)) ∈ ℝ)
3 simpl 482 . . . . 5 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → 𝐴 ∈ ℝ)
4 rpregt0 12924 . . . . . 6 (𝐵 ∈ ℝ+ → (𝐵 ∈ ℝ ∧ 0 < 𝐵))
54adantl 481 . . . . 5 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → (𝐵 ∈ ℝ ∧ 0 < 𝐵))
6 lemuldiv2 12027 . . . . 5 (((⌊‘(𝐴 / 𝐵)) ∈ ℝ ∧ 𝐴 ∈ ℝ ∧ (𝐵 ∈ ℝ ∧ 0 < 𝐵)) → ((𝐵 · (⌊‘(𝐴 / 𝐵))) ≤ 𝐴 ↔ (⌊‘(𝐴 / 𝐵)) ≤ (𝐴 / 𝐵)))
72, 3, 5, 6syl3anc 1374 . . . 4 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → ((𝐵 · (⌊‘(𝐴 / 𝐵))) ≤ 𝐴 ↔ (⌊‘(𝐴 / 𝐵)) ≤ (𝐴 / 𝐵)))
81, 7mpbird 257 . . 3 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → (𝐵 · (⌊‘(𝐴 / 𝐵))) ≤ 𝐴)
9 rpre 12918 . . . . . 6 (𝐵 ∈ ℝ+𝐵 ∈ ℝ)
109adantl 481 . . . . 5 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → 𝐵 ∈ ℝ)
1110, 2remulcld 11166 . . . 4 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → (𝐵 · (⌊‘(𝐴 / 𝐵))) ∈ ℝ)
12 subge0 11654 . . . 4 ((𝐴 ∈ ℝ ∧ (𝐵 · (⌊‘(𝐴 / 𝐵))) ∈ ℝ) → (0 ≤ (𝐴 − (𝐵 · (⌊‘(𝐴 / 𝐵)))) ↔ (𝐵 · (⌊‘(𝐴 / 𝐵))) ≤ 𝐴))
1311, 12syldan 592 . . 3 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → (0 ≤ (𝐴 − (𝐵 · (⌊‘(𝐴 / 𝐵)))) ↔ (𝐵 · (⌊‘(𝐴 / 𝐵))) ≤ 𝐴))
148, 13mpbird 257 . 2 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → 0 ≤ (𝐴 − (𝐵 · (⌊‘(𝐴 / 𝐵)))))
15 modval 13795 . 2 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → (𝐴 mod 𝐵) = (𝐴 − (𝐵 · (⌊‘(𝐴 / 𝐵)))))
1614, 15breqtrrd 5127 1 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ+) → 0 ≤ (𝐴 mod 𝐵))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395  wcel 2114   class class class wbr 5099  cfv 6493  (class class class)co 7360  cr 11029  0cc0 11030   · cmul 11035   < clt 11170  cle 11171  cmin 11368   / cdiv 11798  +crp 12909  cfl 13714   mod cmo 13793
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1912  ax-6 1969  ax-7 2010  ax-8 2116  ax-9 2124  ax-10 2147  ax-11 2163  ax-12 2185  ax-ext 2709  ax-sep 5242  ax-nul 5252  ax-pow 5311  ax-pr 5378  ax-un 7682  ax-cnex 11086  ax-resscn 11087  ax-1cn 11088  ax-icn 11089  ax-addcl 11090  ax-addrcl 11091  ax-mulcl 11092  ax-mulrcl 11093  ax-mulcom 11094  ax-addass 11095  ax-mulass 11096  ax-distr 11097  ax-i2m1 11098  ax-1ne0 11099  ax-1rid 11100  ax-rnegex 11101  ax-rrecex 11102  ax-cnre 11103  ax-pre-lttri 11104  ax-pre-lttrn 11105  ax-pre-ltadd 11106  ax-pre-mulgt0 11107  ax-pre-sup 11108
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 849  df-3or 1088  df-3an 1089  df-tru 1545  df-fal 1555  df-ex 1782  df-nf 1786  df-sb 2069  df-mo 2540  df-eu 2570  df-clab 2716  df-cleq 2729  df-clel 2812  df-nfc 2886  df-ne 2934  df-nel 3038  df-ral 3053  df-rex 3062  df-rmo 3351  df-reu 3352  df-rab 3401  df-v 3443  df-sbc 3742  df-csb 3851  df-dif 3905  df-un 3907  df-in 3909  df-ss 3919  df-pss 3922  df-nul 4287  df-if 4481  df-pw 4557  df-sn 4582  df-pr 4584  df-op 4588  df-uni 4865  df-iun 4949  df-br 5100  df-opab 5162  df-mpt 5181  df-tr 5207  df-id 5520  df-eprel 5525  df-po 5533  df-so 5534  df-fr 5578  df-we 5580  df-xp 5631  df-rel 5632  df-cnv 5633  df-co 5634  df-dm 5635  df-rn 5636  df-res 5637  df-ima 5638  df-pred 6260  df-ord 6321  df-on 6322  df-lim 6323  df-suc 6324  df-iota 6449  df-fun 6495  df-fn 6496  df-f 6497  df-f1 6498  df-fo 6499  df-f1o 6500  df-fv 6501  df-riota 7317  df-ov 7363  df-oprab 7364  df-mpo 7365  df-om 7811  df-2nd 7936  df-frecs 8225  df-wrecs 8256  df-recs 8305  df-rdg 8343  df-er 8637  df-en 8888  df-dom 8889  df-sdom 8890  df-sup 9349  df-inf 9350  df-pnf 11172  df-mnf 11173  df-xr 11174  df-ltxr 11175  df-le 11176  df-sub 11370  df-neg 11371  df-div 11799  df-nn 12150  df-n0 12406  df-z 12493  df-uz 12756  df-rp 12910  df-fl 13716  df-mod 13794
This theorem is referenced by:  modelico  13805  zmodcl  13815  modid2  13822  modabs  13828  modltm1p1mod  13850  modsubdir  13867  modeqmodmin  13868  digit1  14164  bitsinv1lem  16372  4sqlem6  16875  sineq0  26493  efif1olem2  26512  irrapxlem1  43100  pellfund14  43176  jm2.19  43271  sineq0ALT  45213  fourierswlem  46510  fouriersw  46511
  Copyright terms: Public domain W3C validator