From owner-svn-src-head@freebsd.org Sun May 22 00:58:17 2016 Return-Path: Delivered-To: svn-src-head@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id D6030B3B2DF; Sun, 22 May 2016 00:58:17 +0000 (UTC) (envelope-from brde@optusnet.com.au) Received: from mail105.syd.optusnet.com.au (mail105.syd.optusnet.com.au [211.29.132.249]) by mx1.freebsd.org (Postfix) with ESMTP id 9D6F81D73; Sun, 22 May 2016 00:58:16 +0000 (UTC) (envelope-from brde@optusnet.com.au) Received: from c122-106-149-109.carlnfd1.nsw.optusnet.com.au (c122-106-149-109.carlnfd1.nsw.optusnet.com.au [122.106.149.109]) by mail105.syd.optusnet.com.au (Postfix) with ESMTPS id 87C631047D8C; Sun, 22 May 2016 10:58:06 +1000 (AEST) Date: Sun, 22 May 2016 10:58:05 +1000 (EST) From: Bruce Evans X-X-Sender: bde@besplex.bde.org To: Conrad Meyer cc: Bruce Evans , Konstantin Belousov , src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org Subject: Re: svn commit: r300332 - in head/sys: amd64/amd64 i386/i386 In-Reply-To: Message-ID: <20160522101943.U1190@besplex.bde.org> References: <201605201950.u4KJoWA5028092@repo.freebsd.org> <20160521081930.I1098@besplex.bde.org> <20160521103528.I1539@besplex.bde.org> <20160521123908.V1914@besplex.bde.org> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII; format=flowed X-Optus-CM-Score: 0 X-Optus-CM-Analysis: v=2.1 cv=M8SwUHEs c=1 sm=1 tr=0 a=R/f3m204ZbWUO/0rwPSMPw==:117 a=L9H7d07YOLsA:10 a=9cW_t1CCXrUA:10 a=s5jvgZ67dGcA:10 a=kj9zAlcOel0A:10 a=PO7r1zJSAAAA:8 a=hCGAsxolkOEVDU5JMAgA:9 a=CjuIK1q_8ugA:10 a=Oa0T6EYmKFNB-xRHvYM1:22 X-BeenThere: svn-src-head@freebsd.org X-Mailman-Version: 2.1.22 Precedence: list List-Id: SVN commit messages for the src tree for head/-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 22 May 2016 00:58:17 -0000 On Sat, 21 May 2016, Conrad Meyer wrote: > On Fri, May 20, 2016 at 9:13 PM, Bruce Evans wrote: >> On Fri, 20 May 2016, Conrad Meyer wrote: >> >>> On Fri, May 20, 2016 at 6:10 PM, Bruce Evans wrote: >>>> >>>> >>>> Signed integers are easier to understand provided calculations with them >>>> don't overflow. >>> >>> How? >> >> For the same reasons as in applying mathematics. Applying mathematics >> ... >> Ordinary (real) numbers (including negative ones) also have good ordering >> properties for all operations. >> >> Computer arithmetic can't represent all ordinary numbers, but gets closest >> by representing ordinary integers as C signed integers perfectly when no >> overflow occurs. >> >> By using C unsigned integers unnecessarily, you throw out invention of >> negative numbers and might have to work with the unfamiliar and badly >> behaved ordering on them. C programmers have some experience with this >> ordering, but apparently not enough to usually avoid bugs. >> ... > Thanks for explaining. > > Can you explain a little bit about the badly behaved ordering of > unsigned integers? I am not familiar with that. The strongest ordering properties for real numbers depend on the existence of negative numbers (and zero). E.g., x >= y if and only if x - y >= 0. To apply that, you need the more basic property that the ordering keeps negative numbers separate from strictly positive numbers and zero. Without negative numbers, we can hope for weaker properties. One is that x1 <= x2 implies x1 + y <= x2 + y. The is true for C signed and unsigned integers if there is no overflow, but for the unsigned case overflow is often considered normal and is technically not described as overflow. Ordering for multiplication breaks down similarly. Division has complications before considering ordering, so don't consider it. Ordering for subtraction breaks down more than for addition, despite it working perfectly as a (reversible) algebraic operator for the unsigned case. Overflow causes problems as usual, and subtraction of unsigned values x - y always "overflows" if y is larger. Signed integers work especially well for subtraction if the operands are non-negative, since then it never overflows. Bruce