#!/usr/bin/ruby
#
## https://rosettacode.org/wiki/Extreme_floating_point_values
#
var inf = (1 / 0) #=> Inf
var nan = (0 / 0) #=> NaN
var exprs = [
"1.0 / 0.0", "-1.0 / 0.0", "0.0 / 0.0", "- 0.0",
"inf + 1", "5 - inf", "inf * 5", "inf / 5", "inf * 0",
"1.0 / inf", "-1.0 / inf", "inf + inf", "inf - inf",
"inf * inf", "inf / inf", "inf * 0.0", " 0 < inf", "inf == inf",
"nan + 1", "nan * 5", "nan - nan", "nan * inf", "- nan",
"nan == nan", "nan > 0", "nan < 0", "nan == 0", "0.0 == -0.0",
]
exprs.each { |expr|
"%15s => %s\n".printf(expr, eval(expr))
}
say "-"*40
say("NaN equality: ", NaN == nan) #=> true
say("Infinity equality: ", Inf == inf) #=> true
say("-Infinity equality: ", -Inf == -inf) #=> true
say "-"*40
say("sqrt(-1) = ", sqrt(-1)); #=> i
say("tanh(-Inf) = ", tanh(-inf)); #=> -1
say("(-Inf)**2 = ", (-inf)**2); #=> Inf
say("(-Inf)**3 = ", (-inf)**3); #=> -Inf
say("acos(Inf) = ", acos(inf)); #=> Inf*i
say("atan(Inf) = ", atan(inf)); #=> pi/2
say("log(-1) = ", log(-1)); #=> pi*i
say("atanh(Inf) = ", atanh(inf)); #=> -pi/2*i