Documentation for method Num
assembled from the following pages:
Class: NumStr §
From NumStr
(NumStr) method Num §
method Num
Returns the Num
value of the NumStr
.
Role: Rational §
From Rational
(Rational) method Num §
Defined as:
method Num(Rational: --> Num)
Coerces the invocant to Num by dividing numerator by denominator. If denominator is 0
, returns Inf
, -Inf
, or NaN
, based on whether numerator is a positive number, negative number, or 0
, respectively.
Class: Str §
From Str
(Str) method Num §
Defined as:
method Num(Str: --> Num)
Coerces the string to Num
, using the same rules as Str.Numeric
and handling negative zero, -0e0
, and positive zero, 0e0
.
my Str = "-0/5";say (.self, .^name) given .Numeric; # OUTPUT: «(0 Rat)» say (.self, .^name) given .Num; # OUTPUT: «(-0 Num)»
Class: Num §
From Num
(Num) method Num §
method Num()
Returns the invocant.
Role: Real §
From Real
(Real) method Num §
method Num(Real:)
Calls the Bridge
method on the invocant and then the Num
method on its return value.
Class: Cool §
From Cool
(Cool) method Num §
Defined as:
multi method Num()
Coerces the invocant to a Numeric
and calls its .Num
method. Fails if the coercion to a Numeric
cannot be done.
say 1+0i.Num; # OUTPUT: «1» say 2e1.Num; # OUTPUT: «20» say (16/9)².Num; # OUTPUT: «3.1604938271604937» say (-4/3).Num; # OUTPUT: «-1.3333333333333333» say "foo".Num.^name; # OUTPUT: «Failure»