-
-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
number.cr
123 lines (105 loc) · 3.54 KB
/
number.cr
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
struct BigInt
Number.expand_div [Int8, UInt8, Int16, UInt16, Int32, UInt32, Int64, UInt64, Int128, UInt128], BigFloat
Number.expand_div [Float32, Float64], BigFloat
end
struct BigFloat
def fdiv(other : Number::Primitive) : self
self.class.new(self / other)
end
def /(other : UInt8 | UInt16 | UInt32 | UInt64)
# Division by 0 in BigFloat is not allowed, there is no BigFloat::Infinitiy
raise DivisionByZeroError.new if other == 0
if other.is_a?(UInt8 | UInt16 | UInt32) || (LibGMP::ULong == UInt64 && other.is_a?(UInt64))
BigFloat.new { |mpf| LibGMP.mpf_div_ui(mpf, self, other) }
else
BigFloat.new { |mpf| LibGMP.mpf_div(mpf, self, other.to_big_f) }
end
end
Number.expand_div [Int8, Int16, Int32, Int64, Int128, UInt128], BigFloat
Number.expand_div [Float32, Float64], BigFloat
end
struct BigDecimal
Number.expand_div [Int8, UInt8, Int16, UInt16, Int32, UInt32, Int64, UInt64, Int128, UInt128], BigDecimal
Number.expand_div [Float32, Float64], BigDecimal
end
struct BigRational
Number.expand_div [Int8, UInt8, Int16, UInt16, Int32, UInt32, Int64, UInt64, Int128, UInt128], BigRational
Number.expand_div [Float32, Float64], BigRational
end
struct Int8
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct Int16
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct Int32
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct Int64
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct Int128
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct UInt8
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct UInt16
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct UInt32
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct UInt64
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct UInt128
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct Float
def fdiv(other : BigInt | BigFloat | BigDecimal | BigRational) : self
self.class.new(self / other)
end
end
struct Float32
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end
struct Float64
Number.expand_div [BigInt], BigFloat
Number.expand_div [BigFloat], BigFloat
Number.expand_div [BigDecimal], BigDecimal
Number.expand_div [BigRational], BigRational
end