Project

General

Profile

Actions

Bug #11582

closed

On Solaris, Rational#** returns -Infinity for Rational(0) when passed a negative Float

Added by Eregon (Benoit Daloze) over 8 years ago. Updated 10 months ago.

Status:
Closed
Assignee:
-
Target version:
-
[ruby-core:<unknown>]

Description

For instance,

Rational(0, 1) ** -1.0
=> +Infinity on most platforms, -Infinity on Solaris by default.

The Rational is implicitly converted to the Float value 0.0, and the libm function pow(0.0, -1.0) is called.

Should this kind of behavior be made consistent by Ruby or should we accept this as dependent on the libm/libc used?

They are likely other edges cases for pow() which might differ, and I think in general
Ruby should try to unify these cases so the behavior is consistent across platforms at least for arithmetic.

For more details, please see https://github.com/ruby/rubyspec/issues/134 reported by ngoto.

Actions #1

Updated by nobu (Nobuyoshi Nakada) over 8 years ago

Does 0.0 ** -1 return -Infinity too?
It isn't a problem?

Updated by ngoto (Naohisa Goto) over 8 years ago

Does 0.0 ** -1 return -Infinity too?

Yes, with default compiler option.
On Solaris, the 0.0 ** -1 could return 3 different values depending on compile-time options: 0, -Infinity, +Infinity.

See below for list of corner-case variations of numerical calculations.
http://docs.oracle.com/cd/E37069_01/html/E39019/z4000ac610479.html

It isn't a problem?

I don't know.

Updated by jeremyevans0 (Jeremy Evans) 10 months ago

  • Status changed from Open to Third Party's Issue

This is an inconsistency in the default behavior of the Solaris pow function compared to other platforms. You could file this as a bug in the Illumios bug tracker (or raise an issue with Oracle Solaris support) if you would like them to change the behavior: https://www.illumos.org/projects/illumos-gate/issues

Updated by ngoto (Naohisa Goto) 10 months ago

  • Status changed from Third Party's Issue to Closed

This issue is solved by [Misc #15347].

In the C99 spec, The behavior of pow(3) in corner cases are clearly defined.
Since Ruby 2.7, C99 is required to compile CRuby source code, and thus Ruby's pow method conforms to the C99 standard.

Actions

Also available in: Atom PDF

Like0
Like0Like0Like0Like0