Users' Mathboxes Mathbox for Thierry Arnoux < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  sgnmulsgp Structured version   Visualization version   GIF version

Theorem sgnmulsgp 32545
Description: If two real numbers are of different signs, so are their signs. (Contributed by Thierry Arnoux, 12-Oct-2018.)
Assertion
Ref Expression
sgnmulsgp ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) → (0 < (𝐴 · 𝐵) ↔ 0 < ((sgn‘𝐴) · (sgn‘𝐵))))

Proof of Theorem sgnmulsgp
StepHypRef Expression
1 0lt1 11525 . . . . 5 0 < 1
2 breq2 5081 . . . . 5 ((sgn‘(𝐴 · 𝐵)) = 1 → (0 < (sgn‘(𝐴 · 𝐵)) ↔ 0 < 1))
31, 2mpbiri 257 . . . 4 ((sgn‘(𝐴 · 𝐵)) = 1 → 0 < (sgn‘(𝐴 · 𝐵)))
43adantl 481 . . 3 (((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ (sgn‘(𝐴 · 𝐵)) = 1) → 0 < (sgn‘(𝐴 · 𝐵)))
5 simplr 765 . . . . . 6 ((((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) ∧ (sgn‘(𝐴 · 𝐵)) = -1) → 0 < (sgn‘(𝐴 · 𝐵)))
6 simpr 484 . . . . . 6 ((((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) ∧ (sgn‘(𝐴 · 𝐵)) = -1) → (sgn‘(𝐴 · 𝐵)) = -1)
75, 6breqtrd 5103 . . . . 5 ((((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) ∧ (sgn‘(𝐴 · 𝐵)) = -1) → 0 < -1)
8 1nn0 12277 . . . . . . . 8 1 ∈ ℕ0
9 nn0nlt0 12287 . . . . . . . 8 (1 ∈ ℕ0 → ¬ 1 < 0)
108, 9ax-mp 5 . . . . . . 7 ¬ 1 < 0
11 1re 11003 . . . . . . . 8 1 ∈ ℝ
12 lt0neg1 11509 . . . . . . . 8 (1 ∈ ℝ → (1 < 0 ↔ 0 < -1))
1311, 12ax-mp 5 . . . . . . 7 (1 < 0 ↔ 0 < -1)
1410, 13mtbi 321 . . . . . 6 ¬ 0 < -1
1514a1i 11 . . . . 5 ((((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) ∧ (sgn‘(𝐴 · 𝐵)) = -1) → ¬ 0 < -1)
167, 15pm2.21dd 194 . . . 4 ((((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) ∧ (sgn‘(𝐴 · 𝐵)) = -1) → (sgn‘(𝐴 · 𝐵)) = 1)
17 simpr 484 . . . . 5 ((((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) ∧ (sgn‘(𝐴 · 𝐵)) = 0) → (sgn‘(𝐴 · 𝐵)) = 0)
18 simplr 765 . . . . . 6 ((((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) ∧ (sgn‘(𝐴 · 𝐵)) = 0) → 0 < (sgn‘(𝐴 · 𝐵)))
1918gt0ne0d 11567 . . . . 5 ((((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) ∧ (sgn‘(𝐴 · 𝐵)) = 0) → (sgn‘(𝐴 · 𝐵)) ≠ 0)
2017, 19pm2.21ddne 3024 . . . 4 ((((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) ∧ (sgn‘(𝐴 · 𝐵)) = 0) → (sgn‘(𝐴 · 𝐵)) = 1)
21 simpr 484 . . . 4 ((((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) ∧ (sgn‘(𝐴 · 𝐵)) = 1) → (sgn‘(𝐴 · 𝐵)) = 1)
22 remulcl 10984 . . . . . . 7 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) → (𝐴 · 𝐵) ∈ ℝ)
2322rexrd 11053 . . . . . 6 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) → (𝐴 · 𝐵) ∈ ℝ*)
2423adantr 480 . . . . 5 (((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) → (𝐴 · 𝐵) ∈ ℝ*)
25 sgncl 32533 . . . . 5 ((𝐴 · 𝐵) ∈ ℝ* → (sgn‘(𝐴 · 𝐵)) ∈ {-1, 0, 1})
26 eltpi 4626 . . . . 5 ((sgn‘(𝐴 · 𝐵)) ∈ {-1, 0, 1} → ((sgn‘(𝐴 · 𝐵)) = -1 ∨ (sgn‘(𝐴 · 𝐵)) = 0 ∨ (sgn‘(𝐴 · 𝐵)) = 1))
2724, 25, 263syl 18 . . . 4 (((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) → ((sgn‘(𝐴 · 𝐵)) = -1 ∨ (sgn‘(𝐴 · 𝐵)) = 0 ∨ (sgn‘(𝐴 · 𝐵)) = 1))
2816, 20, 21, 27mpjao3dan 1429 . . 3 (((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) ∧ 0 < (sgn‘(𝐴 · 𝐵))) → (sgn‘(𝐴 · 𝐵)) = 1)
294, 28impbida 797 . 2 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) → ((sgn‘(𝐴 · 𝐵)) = 1 ↔ 0 < (sgn‘(𝐴 · 𝐵))))
30 sgnpbi 32541 . . 3 ((𝐴 · 𝐵) ∈ ℝ* → ((sgn‘(𝐴 · 𝐵)) = 1 ↔ 0 < (𝐴 · 𝐵)))
3123, 30syl 17 . 2 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) → ((sgn‘(𝐴 · 𝐵)) = 1 ↔ 0 < (𝐴 · 𝐵)))
32 sgnmul 32537 . . 3 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) → (sgn‘(𝐴 · 𝐵)) = ((sgn‘𝐴) · (sgn‘𝐵)))
3332breq2d 5089 . 2 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) → (0 < (sgn‘(𝐴 · 𝐵)) ↔ 0 < ((sgn‘𝐴) · (sgn‘𝐵))))
3429, 31, 333bitr3d 308 1 ((𝐴 ∈ ℝ ∧ 𝐵 ∈ ℝ) → (0 < (𝐴 · 𝐵) ↔ 0 < ((sgn‘𝐴) · (sgn‘𝐵))))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 205  wa 395  w3o 1084   = wceq 1537  wcel 2101  {ctp 4568   class class class wbr 5077  cfv 6447  (class class class)co 7295  cr 10898  0cc0 10899  1c1 10900   · cmul 10904  *cxr 11036   < clt 11037  -cneg 11234  0cn0 12261  sgncsgn 14825
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 2103  ax-9 2111  ax-10 2132  ax-11 2149  ax-12 2166  ax-ext 2704  ax-sep 5226  ax-nul 5233  ax-pow 5291  ax-pr 5355  ax-un 7608  ax-cnex 10955  ax-resscn 10956  ax-1cn 10957  ax-icn 10958  ax-addcl 10959  ax-addrcl 10960  ax-mulcl 10961  ax-mulrcl 10962  ax-mulcom 10963  ax-addass 10964  ax-mulass 10965  ax-distr 10966  ax-i2m1 10967  ax-1ne0 10968  ax-1rid 10969  ax-rnegex 10970  ax-rrecex 10971  ax-cnre 10972  ax-pre-lttri 10973  ax-pre-lttrn 10974  ax-pre-ltadd 10975  ax-pre-mulgt0 10976
This theorem depends on definitions:  df-bi 206  df-an 396  df-or 844  df-3or 1086  df-3an 1087  df-tru 1540  df-fal 1550  df-ex 1778  df-nf 1782  df-sb 2063  df-mo 2535  df-eu 2564  df-clab 2711  df-cleq 2725  df-clel 2811  df-nfc 2884  df-ne 2939  df-nel 3045  df-ral 3060  df-rex 3069  df-rmo 3222  df-reu 3223  df-rab 3224  df-v 3436  df-sbc 3719  df-csb 3835  df-dif 3892  df-un 3894  df-in 3896  df-ss 3906  df-pss 3908  df-nul 4260  df-if 4463  df-pw 4538  df-sn 4565  df-pr 4567  df-tp 4569  df-op 4571  df-uni 4842  df-iun 4929  df-br 5078  df-opab 5140  df-mpt 5161  df-tr 5195  df-id 5491  df-eprel 5497  df-po 5505  df-so 5506  df-fr 5546  df-we 5548  df-xp 5597  df-rel 5598  df-cnv 5599  df-co 5600  df-dm 5601  df-rn 5602  df-res 5603  df-ima 5604  df-pred 6206  df-ord 6273  df-on 6274  df-lim 6275  df-suc 6276  df-iota 6399  df-fun 6449  df-fn 6450  df-f 6451  df-f1 6452  df-fo 6453  df-f1o 6454  df-fv 6455  df-riota 7252  df-ov 7298  df-oprab 7299  df-mpo 7300  df-om 7733  df-2nd 7852  df-frecs 8117  df-wrecs 8148  df-recs 8222  df-rdg 8261  df-er 8518  df-en 8754  df-dom 8755  df-sdom 8756  df-pnf 11039  df-mnf 11040  df-xr 11041  df-ltxr 11042  df-le 11043  df-sub 11235  df-neg 11236  df-div 11661  df-nn 12002  df-n0 12262  df-rp 12759  df-sgn 14826
This theorem is referenced by:  signsvfpn  32592
  Copyright terms: Public domain W3C validator