From owner-svn-src-head@freebsd.org Tue May 31 14:17:57 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 A8DE5B54B6F; Tue, 31 May 2016 14:17:57 +0000 (UTC) (envelope-from brde@optusnet.com.au) Received: from mail108.syd.optusnet.com.au (mail108.syd.optusnet.com.au [211.29.132.59]) by mx1.freebsd.org (Postfix) with ESMTP id 3DCA71F21; Tue, 31 May 2016 14:17:56 +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 mail108.syd.optusnet.com.au (Postfix) with ESMTPS id 2088B1A2FFB; Wed, 1 Jun 2016 00:17:47 +1000 (AEST) Date: Wed, 1 Jun 2016 00:17:47 +1000 (EST) From: Bruce Evans X-X-Sender: bde@besplex.bde.org To: Andrey Chernov cc: pfg@freebsd.org, src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org Subject: Re: svn commit: r300956 - head/lib/libc/stdlib In-Reply-To: Message-ID: <20160531224808.F3933@besplex.bde.org> References: <201605291357.u4TDv6No071840@repo.freebsd.org> <20160530110541.I924@besplex.bde.org> <20160531155327.I1534@besplex.bde.org> <20160531185907.Y2047@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=EfU1O6SC 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=YcMFh1NDAAAA:8 a=q67_N1wWW2dDZDP7g5AA:9 a=CjuIK1q_8ugA:10 a=XzeFQDB4FLgTs7H1q4LV: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: Tue, 31 May 2016 14:17:57 -0000 On Tue, 31 May 2016, Andrey Chernov wrote: > On 31.05.2016 12:58, Bruce Evans wrote: >> On Tue, 31 May 2016, Andrey Chernov wrote: > ... >>> You can download SPRNG library implementing all of them here: >>> http://www.sprng.org/RNG/ >>> For me it is overcomplicated. >> >> The general case is certainly too complicated. It would let the user >> specify all the parameters for the LCG and generate optimal code for >> the choice on the fly. Maybe also change the parameters with the seed. >> But even most implementors don't know how to choose the parameters. >> That's just for the not so good LCG family of RNGs. > > All mentioned PRNGs with exact parameters (info.h) can be found in the > subdirs under SRC, f.e. lcg64 or pmlcfg. They are still looks > complicated and use GMP Bignum library for calculations. Our rand should use just 1, and it is dangerous to change RAND_MAX again, but can we even change the sequences? Something might depend on reproducing the old sequences. >>> For fixups, see full >>> explanation in the comment of stdlib/div.c >> >> That was what I was complaining about. div.c is for C90 (misspelled >> "ANSI"). div.c hasn't caught up with C99. C99 broke this by changing >> ... >> >> In C90, div() is specified as giving "reliable" division, and that is >> what the fixups implement. This now wastes time to change nothing. >> If the hardware does correct rounding, then the compiler already >> had to do the fixup and id should have produced good MD code for this. >> The C code then adds not so good MI code. > > It seems POSIX says nothing about any fixup and negative results: > "These functions shall compute the quotient and remainder of the > division of the numerator numer by the denominator denom. If the > division is inexact, the resulting quotient is the long integer (for the > ldiv( ) function) or long long integer (for the lldiv( ) function) of > lesser magnitude that is the nearest to the algebraic quotient. If the > result cannot be represented, the behavior is undefined; otherwise, quot > * denom+rem shall equal numer." This uses the same not so good wording as C90. "algebraic" means "in the field of ordinary rational numbers", not in a general algebraic object. Then we use the ordering property of the rationals, so we're closer to analysis than algebra. POSIX doesn't define the division operator, and the difference is only there, except for bugs in the wording. In C90, the rounding can go either way so the fixup is needed, but in C99 and C11 the division operator is intended to be specified to do the same rounding as div() used to be specified to do, but with the unimproved wording "the result [of division] is the algebraic quotient with any fractional part discarded". C99 and C11 remove the special wording for div(). This removes all ordering requirements from the standard (1 was moved to a footnote), so C has "unreliable" division again, depending on the unspecified choice of sign for the fractional part. > Does it mean that this fixup should be removed? Just ifdef it for < C99. This corresponds to removing the special wording in >= C99. Bruce