From owner-freebsd-current Thu Oct 31 22: 2: 6 2002 Delivered-To: freebsd-current@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id ECCB937B401 for ; Thu, 31 Oct 2002 22:02:04 -0800 (PST) Received: from mailman.zeta.org.au (mailman.zeta.org.au [203.26.10.16]) by mx1.FreeBSD.org (Postfix) with ESMTP id F36F443E4A for ; Thu, 31 Oct 2002 22:02:03 -0800 (PST) (envelope-from bde@zeta.org.au) Received: from bde.zeta.org.au (bde.zeta.org.au [203.2.228.102]) by mailman.zeta.org.au (8.9.3/8.8.7) with ESMTP id RAA23043; Fri, 1 Nov 2002 17:01:48 +1100 Date: Fri, 1 Nov 2002 17:13:08 +1100 (EST) From: Bruce Evans X-X-Sender: bde@gamplex.bde.org To: "M. Warner Losh" Cc: tlambert2@mindspring.com, , , , Subject: Re: Lack of real long double support In-Reply-To: <20021031.151847.03097281.imp@bsdimp.com> Message-ID: <20021101165954.M14075-100000@gamplex.bde.org> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: owner-freebsd-current@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG On Thu, 31 Oct 2002, M. Warner Losh wrote: > In message: <3DC17FC5.AF56552E@mindspring.com> > Terry Lambert writes: > : "M. Warner Losh" wrote: > : > : I await an explanation of how you can fit 2*DBL_MAX into a double, > : > : which has a range of DBL_MIN..DBL_MAX. > : > > : > Look at the code. > : > > : > long double a = DBL_MAX; > : > long double b = DBL_MAX * 2; > : > > : > The original posting said that b would be +Inf at this point, which is > : > not correct. I think that Bruce was confused there. The more correct > : > example to look at was the one that rittle@ posted which was 1 + > : > LDBL_EPSILON. > : > : I guess I must not be understanding. What will b be, at this point, > : then? How can it have a value larger than DBL_MAX that's not +Inf? > : > : If it's possible to represent a value larger than DBL_MAX in a double, > : then the value of DBL_MAX is wrong, right? Maximum means maximum, > : doesn't it? > > *LONG*DOUBLE* is not *DOUBLE*. long double has extended precision and > a range compared to double. That's how. To beat this dead horse some more: look at the code carefully. It was long double x= DBL_MAX; long double y = 2 * x; /* (1) */ This is quite different from the above, which (after renaming variables and changing the formatting to be bug for bug compatible) is: long double x= DBL_MAX; long double y = DBL_MAX * 2; /* (2) */ In (1), we have DBL_MAX in a long double, so we can expect to double it if long doubles are longer than doubles (whether they actually are is machine-dependent). In (2), we are doubling DBL_MAX as a double. The result of this is fuzzy, since the computation may be done in double precision or long double precision or perhaps something weirder. There will be no way to tell until C99 is implemented and perhaps not even then. gcc things that it is implementing C99's FLT_EVAL_METHOD of 0, which performs arithmetic on doubles in double precision, so the result of DBL_MAX * 2 is +Inf if the this is evaluated at compile time. gcc (gcc-3.2 on i386's) doesn't actually implement this, since the result is not +Inf if DBL_MAX * 2 is evaluated at runtime. Bruce To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message