Project

General

Profile

ActionsLike0

Bug #11582

closed

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

Added by Eregon (Benoit Daloze) about 9 years ago. Updated over 1 year 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.

Like0Actions #1

Updated by nobu (Nobuyoshi Nakada) about 9 years ago

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

Updated by ngoto (Naohisa Goto) about 9 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) over 1 year 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) over 1 year 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.

ActionsLike0

Also available in: Atom PDF