Re: Float/Double cast to int - Mailing list pgsql-hackers

From Tom Lane
Subject Re: Float/Double cast to int
Date
Msg-id 32603.1432234885@sss.pgh.pa.us
Whole thread Raw
In response to Float/Double cast to int  (Feng Tian <ftian@vitessedata.com>)
Responses Re: Float/Double cast to int
List pgsql-hackers
Feng Tian <ftian@vitessedata.com> writes:
> Here is a query, server was built witch GCC on Linux, AMD64.

> ftian=# select 1.5::int, 1.5::double precision::int, 314.5::int,
> 314.5::double precision::int;
>  int4 | int4 | int4 | int4
> ------+------+------+------
>     2 |    2 |  315 |  314
> (1 row)

> I believe this is because rint is broken -- can some expert on IEEE754
> please help confirm that this is a bug?

rint() is doing what the IEEE spec says, ie round to nearest even.
Your third expression is doing numeric-to-int, and that code doesn't
obey the IEEE spec.  We've had discussions (not too long ago) about
making these behaviors more consistent, but people seem to be too
afraid of backwards-compatibility problems if we change it.
        regards, tom lane



pgsql-hackers by date:

Previous
From: Simon Riggs
Date:
Subject: Re: INSERT ... ON CONFLICT DO UPDATE with _any_ constraint
Next
From: Tom Lane
Date:
Subject: Re: GROUPING