Class: Complex
Constant Summary
- I =
new(0, 1)
Instance Attribute Summary collapse
-
#imag ⇒ Object
(also: #imaginary)
readonly
Returns the value of attribute imag.
-
#real ⇒ Object
readonly
Returns the value of attribute real.
Class Method Summary
collapse
Instance Method Summary
collapse
Methods inherited from Numeric
#%, #+@, #<=>, #__coerced__, #ceil, #clone, #div, #divmod, #dup, #floor, #i, #integer?, #negative?, #nonzero?, #positive?, #round, #to_c, #to_int, #truncate, #zero?
Methods included from Comparable
#<, #<=, #>, #>=, #between?, #clamp, normalize
Constructor Details
#initialize(real, imag = 0) ⇒ Complex
Returns a new instance of Complex
[View source]
26
27
28
29
|
# File 'opal/opal/corelib/complex.rb', line 26
def initialize(real, imag = 0)
@real = real
@imag = imag
end
|
Instance Attribute Details
#imag ⇒ Object
Also known as:
imaginary
Returns the value of attribute imag
24
25
26
|
# File 'opal/opal/corelib/complex.rb', line 24
def imag
@imag
end
|
Returns the value of attribute real
24
25
26
|
# File 'opal/opal/corelib/complex.rb', line 24
def real
@real
end
|
Class Method Details
.polar(r, theta = 0) ⇒ Object
[View source]
16
17
18
19
20
21
22
|
# File 'opal/opal/corelib/complex.rb', line 16
def self.polar(r, theta = 0)
unless Numeric === r && r.real? && Numeric === theta && theta.real?
raise TypeError, 'not a real'
end
new(r * Math.cos(theta), r * Math.sin(theta))
end
|
.rect(real, imag = 0) ⇒ Object
[View source]
4
5
6
7
8
9
10
|
# File 'opal/opal/corelib/complex.rb', line 4
def self.rect(real, imag = 0)
unless Numeric === real && real.real? && Numeric === imag && imag.real?
raise TypeError, 'not a real'
end
new(real, imag)
end
|
.rectangular ⇒ Object
[View source]
13
14
15
16
17
18
19
|
# File 'opal/opal/corelib/complex.rb', line 13
def self.rect(real, imag = 0)
unless Numeric === real && real.real? && Numeric === imag && imag.real?
raise TypeError, 'not a real'
end
new(real, imag)
end
|
Instance Method Details
[View source]
75
76
77
78
79
80
81
82
83
84
|
# File 'opal/opal/corelib/complex.rb', line 75
def *(other)
if Complex === other
Complex(@real * other.real - @imag * other.imag,
@real * other.imag + @imag * other.real)
elsif Numeric === other && other.real?
Complex(@real * other, @imag * other)
else
__coerced__ :*, other
end
end
|
#**(other) ⇒ Object
[View source]
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
|
# File 'opal/opal/corelib/complex.rb', line 101
def **(other)
if other == 0
return Complex.new(1, 0)
end
if Complex === other
r, theta = polar
ore = other.real
oim = other.imag
nr = Math.exp(ore * Math.log(r) - oim * theta)
ntheta = theta * ore + oim * Math.log(r)
Complex.polar(nr, ntheta)
elsif Integer === other
if other > 0
x = self
z = x
n = other - 1
while n != 0
while (div, mod = n.divmod(2); mod == 0)
x = Complex(x.real * x.real - x.imag * x.imag, 2 * x.real * x.imag)
n = div
end
z *= x
n -= 1
end
z
else
(Rational.new(1, 1) / self) ** -other
end
elsif Float === other || Rational === other
r, theta = polar
Complex.polar(r ** other, theta * other)
else
__coerced__ :**, other
end
end
|
[View source]
55
56
57
58
59
60
61
62
63
|
# File 'opal/opal/corelib/complex.rb', line 55
def +(other)
if Complex === other
Complex(@real + other.real, @imag + other.imag)
elsif Numeric === other && other.real?
Complex(@real + other, @imag)
else
__coerced__ :+, other
end
end
|
[View source]
65
66
67
68
69
70
71
72
73
|
# File 'opal/opal/corelib/complex.rb', line 65
def -(other)
if Complex === other
Complex(@real - other.real, @imag - other.imag)
elsif Numeric === other && other.real?
Complex(@real - other, @imag)
else
__coerced__ :-, other
end
end
|
[View source]
51
52
53
|
# File 'opal/opal/corelib/complex.rb', line 51
def -@
Complex(-@real, -@imag)
end
|
#/(other) ⇒ Object
Also known as:
divide, quo
[View source]
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
# File 'opal/opal/corelib/complex.rb', line 86
def /(other)
if Complex === other
if (Number === @real && @real.nan?) || (Number === @imag && @imag.nan?) ||
(Number === other.real && other.real.nan?) || (Number === other.imag && other.imag.nan?)
Complex.new(Float::NAN, Float::NAN)
else
self * other.conj / other.abs2
end
elsif Numeric === other && other.real?
Complex(@real.quo(other), @imag.quo(other))
else
__coerced__ :/, other
end
end
|
#==(other) ⇒ Object
[View source]
41
42
43
44
45
46
47
48
49
|
# File 'opal/opal/corelib/complex.rb', line 41
def ==(other)
if Complex === other
@real == other.real && @imag == other.imag
elsif Numeric === other && other.real?
@real == other && @imag == 0
else
other == self
end
end
|
#abs ⇒ Object
Also known as:
magnitude
[View source]
143
144
145
|
# File 'opal/opal/corelib/complex.rb', line 143
def abs
Math.hypot(@real, @imag)
end
|
[View source]
147
148
149
|
# File 'opal/opal/corelib/complex.rb', line 147
def abs2
@real * @real + @imag * @imag
end
|
#angle ⇒ Object
Also known as:
arg
[View source]
151
152
153
|
# File 'opal/opal/corelib/complex.rb', line 151
def angle
Math.atan2(@imag, @real)
end
|
#coerce(other) ⇒ Object
[View source]
31
32
33
34
35
36
37
38
39
|
# File 'opal/opal/corelib/complex.rb', line 31
def coerce(other)
if Complex === other
[other, self]
elsif Numeric === other && other.real?
[Complex.new(other, 0), self]
else
raise TypeError, "#{other.class} can't be coerced into Complex"
end
end
|
#conj ⇒ Object
Also known as:
conjugate
[View source]
157
158
159
|
# File 'opal/opal/corelib/complex.rb', line 157
def conj
Complex(@real, -@imag)
end
|
#denominator ⇒ Object
[View source]
163
164
165
|
# File 'opal/opal/corelib/complex.rb', line 163
def denominator
@real.denominator.lcm(@imag.denominator)
end
|
#eql?(other) ⇒ Boolean
[View source]
169
170
171
|
# File 'opal/opal/corelib/complex.rb', line 169
def eql?(other)
Complex === other && @real.class == @imag.class && self == other
end
|
#fdiv(other) ⇒ Object
[View source]
173
174
175
176
177
178
179
|
# File 'opal/opal/corelib/complex.rb', line 173
def fdiv(other)
unless Numeric === other
raise TypeError, "#{other.class} can't be coerced into Complex"
end
self / other
end
|
[View source]
181
182
183
|
# File 'opal/opal/corelib/complex.rb', line 181
def hash
"Complex:#@real:#@imag"
end
|
[View source]
187
188
189
|
# File 'opal/opal/corelib/complex.rb', line 187
def inspect
"(#{to_s})"
end
|
#numerator ⇒ Object
[View source]
195
196
197
198
199
200
|
# File 'opal/opal/corelib/complex.rb', line 195
def numerator
d = denominator
Complex(@real.numerator * (d / @real.denominator),
@imag.numerator * (d / @imag.denominator))
end
|
[View source]
204
205
206
|
# File 'opal/opal/corelib/complex.rb', line 204
def polar
[abs, arg]
end
|
#rationalize(eps = undefined) ⇒ Object
[View source]
212
213
214
215
216
217
218
219
220
221
222
223
224
|
# File 'opal/opal/corelib/complex.rb', line 212
def rationalize(eps = undefined)
%x{
if (arguments.length > 1) {
#{raise ArgumentError, "wrong number of arguments (#{`arguments.length`} for 0..1)"};
}
}
if @imag != 0
raise RangeError, "can't' convert #{self} into Rational"
end
real.rationalize(eps)
end
|
[View source]
226
227
228
|
# File 'opal/opal/corelib/complex.rb', line 226
def real?
false
end
|
#rect ⇒ Object
Also known as:
rectangular
[View source]
230
231
232
|
# File 'opal/opal/corelib/complex.rb', line 230
def rect
[@real, @imag]
end
|
[View source]
236
237
238
239
240
241
242
|
# File 'opal/opal/corelib/complex.rb', line 236
def to_f
unless @imag == 0
raise RangeError, "can't convert #{self} into Float"
end
@real.to_f
end
|
[View source]
244
245
246
247
248
249
250
|
# File 'opal/opal/corelib/complex.rb', line 244
def to_i
unless @imag == 0
raise RangeError, "can't convert #{self} into Integer"
end
@real.to_i
end
|
[View source]
252
253
254
255
256
257
258
|
# File 'opal/opal/corelib/complex.rb', line 252
def to_r
unless @imag == 0
raise RangeError, "can't convert #{self} into Rational"
end
@real.to_r
end
|
[View source]
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
|
# File 'opal/opal/corelib/complex.rb', line 260
def to_s
result = @real.inspect
if (Number === @imag && @imag.nan?) || @imag.positive? || @imag.zero?
result += ?+
else
result += ?-
end
result += @imag.abs.inspect
if Number === @imag && (@imag.nan? || @imag.infinite?)
result += ?*
end
result + ?i
end
|