Module: Math
Overview
Defined Under Namespace
Classes: DomainError
Constant Summary
- PI
- E
Class Method Summary (collapse)
-
+ acos
Computes the arc cosine of x.
-
+ acosh
Computes the inverse hyperbolic cosine of x.
-
+ asin
Computes the arc sine of x.
-
+ asinh
Computes the inverse hyperbolic sine of x.
-
+ atan
Computes the arc tangent of x.
-
+ atan2
Computes the arc tangent given y and x.
-
+ atanh
Computes the inverse hyperbolic tangent of x.
-
+ cbrt
Returns the cube root of numeric.
-
+ cos
Computes the cosine of x (expressed in radians).
-
+ cosh
Computes the hyperbolic cosine of x (expressed in radians).
-
+ erf
Calculates the error function of x.
-
+ erfc
Calculates the complementary error function of x.
-
+ exp
Returns e**x.
- + frexp
-
+ gamma
Calculates the gamma function of x.
-
+ hypot
Returns sqrt(x**2 + y**2), the hypotenuse of a right-angled triangle with sides x and y.
-
+ ldexp
Returns the value of flt*(2**int).
-
+ lgamma
Calculates the logarithmic gamma of x and.
-
+ log
Returns the natural logarithm of numeric.
-
+ log10
Returns the base 10 logarithm of numeric.
-
+ log2
Returns the base 2 logarithm of numeric.
-
+ sin
Computes the sine of x (expressed in radians).
-
+ sinh
Computes the hyperbolic sine of x (expressed in radians).
-
+ sqrt
Returns the non-negative square root of numeric.
-
+ tan
Returns the tangent of x (expressed in radians).
-
+ tanh
Computes the hyperbolic tangent of x (expressed in radians).
Class Method Details
+ (Float) acos(x)
Computes the arc cosine of x. Returns 0..PI.
+ (Float) acosh(x)
Computes the inverse hyperbolic cosine of x.
+ (Float) asin(x)
Computes the arc sine of x. Returns -PI/2 .. PI/2.
+ (Float) asinh(x)
Computes the inverse hyperbolic sine of x.
+ (Float) atan(x)
Computes the arc tangent of x. Returns -PI/2 .. PI/2.
+ (Float) atan2(y, x)
Computes the arc tangent given y and x. Returns -PI..PI.
Math.atan2(-0.0, -1.0) #=> -3.141592653589793
Math.atan2(-1.0, -1.0) #=> -2.356194490192345
Math.atan2(-1.0, 0.0) #=> -1.5707963267948966
Math.atan2(-1.0, 1.0) #=> -0.7853981633974483
Math.atan2(-0.0, 1.0) #=> -0.0
Math.atan2(0.0, 1.0) #=> 0.0
Math.atan2(1.0, 1.0) #=> 0.7853981633974483
Math.atan2(1.0, 0.0) #=> 1.5707963267948966
Math.atan2(1.0, -1.0) #=> 2.356194490192345
Math.atan2(0.0, -1.0) #=> 3.141592653589793
+ (Float) atanh(x)
Computes the inverse hyperbolic tangent of x.
+ (Float) cbrt(numeric)
Returns the cube root of numeric.
-9.upto(9) {|x|
p [x, Math.cbrt(x), Math.cbrt(x)**3]
}
#=>
[-9, -2.0800838230519, -9.0]
[-8, -2.0, -8.0]
[-7, -1.91293118277239, -7.0]
[-6, -1.81712059283214, -6.0]
[-5, -1.7099759466767, -5.0]
[-4, -1.5874010519682, -4.0]
[-3, -1.44224957030741, -3.0]
[-2, -1.25992104989487, -2.0]
[-1, -1.0, -1.0]
[0, 0.0, 0.0]
[1, 1.0, 1.0]
[2, 1.25992104989487, 2.0]
[3, 1.44224957030741, 3.0]
[4, 1.5874010519682, 4.0]
[5, 1.7099759466767, 5.0]
[6, 1.81712059283214, 6.0]
[7, 1.91293118277239, 7.0]
[8, 2.0, 8.0]
[9, 2.0800838230519, 9.0]
+ (Float) cos(x)
Computes the cosine of x (expressed in radians). Returns -1..1.
+ (Float) cosh(x)
Computes the hyperbolic cosine of x (expressed in radians).
+ (Float) erf(x)
Calculates the error function of x.
+ (Float) erfc(x)
Calculates the complementary error function of x.
+ (Float) exp(x)
Returns e**x.
Math.exp(0) #=> 1.0
Math.exp(1) #=> 2.718281828459045
Math.exp(1.5) #=> 4.4816890703380645
+ (Array) frexp(numeric)
+ (Float) gamma(x)
Calculates the gamma function of x.
Note that gamma(n) is same as fact(n-1) for integer n > 0.
However gamma(n) returns float and can be an approximation.
def fact(n) (1..n).inject(1) {|r,i| r*i } end
1.upto(26) {|i| p [i, Math.gamma(i), fact(i-1)] }
#=> [1, 1.0, 1]
# [2, 1.0, 1]
# [3, 2.0, 2]
# [4, 6.0, 6]
# [5, 24.0, 24]
# [6, 120.0, 120]
# [7, 720.0, 720]
# [8, 5040.0, 5040]
# [9, 40320.0, 40320]
# [10, 362880.0, 362880]
# [11, 3628800.0, 3628800]
# [12, 39916800.0, 39916800]
# [13, 479001600.0, 479001600]
# [14, 6227020800.0, 6227020800]
# [15, 87178291200.0, 87178291200]
# [16, 1307674368000.0, 1307674368000]
# [17, 20922789888000.0, 20922789888000]
# [18, 355687428096000.0, 355687428096000]
# [19, 6.402373705728e+15, 6402373705728000]
# [20, 1.21645100408832e+17, 121645100408832000]
# [21, 2.43290200817664e+18, 2432902008176640000]
# [22, 5.109094217170944e+19, 51090942171709440000]
# [23, 1.1240007277776077e+21, 1124000727777607680000]
# [24, 2.5852016738885062e+22, 25852016738884976640000]
# [25, 6.204484017332391e+23, 620448401733239439360000]
# [26, 1.5511210043330954e+25, 15511210043330985984000000]
+ (Float) hypot(x, y)
Returns sqrt(x**2 + y**2), the hypotenuse of a right-angled triangle with sides x and y.
Math.hypot(3, 4) #=> 5.0
+ (Float) ldexp(flt, int)
Returns the value of flt*(2**int).
fraction, exponent = Math.frexp(1234)
Math.ldexp(fraction, exponent) #=> 1234.0
+ (Array, ...) lgamma(x)
Calculates the logarithmic gamma of x and
the sign of gamma of x.
Math.lgamma(x) is same as
[Math.log(Math.gamma(x).abs), Math.gamma(x) < 0 ? -1 : 1]
but avoid overflow by Math.gamma(x) for large x.
+ (Float) log(numeric) + (Float) log(num, base)
Returns the natural logarithm of numeric. If additional second argument is given, it will be the base of logarithm.
Math.log(1) #=> 0.0
Math.log(Math::E) #=> 1.0
Math.log(Math::E**3) #=> 3.0
Math.log(12,3) #=> 2.2618595071429146
+ (Float) log10(numeric)
Returns the base 10 logarithm of numeric.
Math.log10(1) #=> 0.0
Math.log10(10) #=> 1.0
Math.log10(10**100) #=> 100.0
+ (Float) log2(numeric)
Returns the base 2 logarithm of numeric.
Math.log2(1) #=> 0.0
Math.log2(2) #=> 1.0
Math.log2(32768) #=> 15.0
Math.log2(65536) #=> 16.0
+ (Float) sin(x)
Computes the sine of x (expressed in radians). Returns -1..1.
+ (Float) sinh(x)
Computes the hyperbolic sine of x (expressed in radians).
+ (Float) sqrt(numeric)
Returns the non-negative square root of numeric.
0.upto(10) {|x|
p [x, Math.sqrt(x), Math.sqrt(x)**2]
}
#=>
[0, 0.0, 0.0]
[1, 1.0, 1.0]
[2, 1.4142135623731, 2.0]
[3, 1.73205080756888, 3.0]
[4, 2.0, 4.0]
[5, 2.23606797749979, 5.0]
[6, 2.44948974278318, 6.0]
[7, 2.64575131106459, 7.0]
[8, 2.82842712474619, 8.0]
[9, 3.0, 9.0]
[10, 3.16227766016838, 10.0]
+ (Float) tan(x)
Returns the tangent of x (expressed in radians).
+ (Float) tanh
Computes the hyperbolic tangent of x (expressed in radians).