multiarray 0.4.1 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/COPYING +1 -1
- data/README.md +3 -0
- data/Rakefile +7 -6
- data/TODO +79 -2
- data/lib/multiarray.rb +452 -31
- data/lib/multiarray/binary.rb +174 -0
- data/lib/multiarray/bool.rb +138 -0
- data/lib/multiarray/diagonal.rb +167 -0
- data/lib/multiarray/element.rb +146 -0
- data/lib/multiarray/gcccache.rb +23 -0
- data/lib/multiarray/gcccontext.rb +144 -0
- data/lib/multiarray/gccfunction.rb +109 -0
- data/lib/multiarray/gcctype.rb +73 -0
- data/lib/multiarray/gccvalue.rb +152 -0
- data/lib/multiarray/index.rb +91 -0
- data/lib/multiarray/inject.rb +143 -0
- data/lib/multiarray/int.rb +238 -13
- data/lib/multiarray/lambda.rb +100 -0
- data/lib/multiarray/list.rb +27 -50
- data/lib/multiarray/lookup.rb +85 -0
- data/lib/multiarray/malloc.rb +28 -2
- data/lib/multiarray/multiarray.rb +44 -30
- data/lib/multiarray/node.rb +596 -0
- data/lib/multiarray/object.rb +74 -31
- data/lib/multiarray/operations.rb +78 -0
- data/lib/multiarray/pointer.rb +134 -4
- data/lib/multiarray/sequence.rb +209 -38
- data/lib/multiarray/unary.rb +170 -0
- data/lib/multiarray/variable.rb +120 -0
- data/test/tc_bool.rb +117 -0
- data/test/tc_int.rb +122 -85
- data/test/tc_multiarray.rb +196 -55
- data/test/tc_object.rb +54 -49
- data/test/tc_sequence.rb +177 -83
- data/test/ts_multiarray.rb +17 -0
- metadata +40 -16
- data/README +0 -1
- data/lib/multiarray/int_.rb +0 -198
- data/lib/multiarray/lazy.rb +0 -81
- data/lib/multiarray/pointer_.rb +0 -260
- data/lib/multiarray/sequence_.rb +0 -155
- data/lib/multiarray/type.rb +0 -207
data/test/tc_multiarray.rb
CHANGED
@@ -1,3 +1,19 @@
|
|
1
|
+
# multiarray - Lazy multi-dimensional arrays for Ruby
|
2
|
+
# Copyright (C) 2010 Jan Wedekind
|
3
|
+
#
|
4
|
+
# This program is free software: you can redistribute it and/or modify
|
5
|
+
# it under the terms of the GNU General Public License as published by
|
6
|
+
# the Free Software Foundation, either version 3 of the License, or
|
7
|
+
# (at your option) any later version.
|
8
|
+
#
|
9
|
+
# This program is distributed in the hope that it will be useful,
|
10
|
+
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
11
|
+
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
12
|
+
# GNU General Public License for more details.
|
13
|
+
#
|
14
|
+
# You should have received a copy of the GNU General Public License
|
15
|
+
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
16
|
+
|
1
17
|
require 'test/unit'
|
2
18
|
begin
|
3
19
|
require 'rubygems'
|
@@ -8,105 +24,230 @@ Kernel::require 'multiarray'
|
|
8
24
|
class TC_MultiArray < Test::Unit::TestCase
|
9
25
|
|
10
26
|
O = Hornetseye::OBJECT
|
27
|
+
B = Hornetseye::BOOL
|
28
|
+
I = Hornetseye::INT
|
29
|
+
S = Hornetseye::Sequence
|
11
30
|
M = Hornetseye::MultiArray
|
12
31
|
|
13
|
-
def
|
14
|
-
Hornetseye::
|
32
|
+
def S( *args )
|
33
|
+
Hornetseye::Sequence *args
|
15
34
|
end
|
16
35
|
|
17
|
-
def
|
18
|
-
Hornetseye::
|
36
|
+
def M( *args )
|
37
|
+
Hornetseye::MultiArray *args
|
19
38
|
end
|
20
39
|
|
21
|
-
def
|
40
|
+
def sum( *args, &action )
|
41
|
+
Hornetseye::sum *args, &action
|
22
42
|
end
|
23
43
|
|
24
|
-
def
|
44
|
+
def eager( *args, &action )
|
45
|
+
Hornetseye::eager *args, &action
|
25
46
|
end
|
26
47
|
|
27
|
-
def
|
28
|
-
Hornetseye::MultiArray *args
|
48
|
+
def setup
|
29
49
|
end
|
30
50
|
|
31
|
-
def
|
32
|
-
assert_equal [ [ nil ] * 3 ] * 2, M( O, 3, 2 ).new.to_a
|
51
|
+
def teardown
|
33
52
|
end
|
34
53
|
|
35
54
|
def test_multiarray_inspect
|
36
|
-
assert_equal 'MultiArray
|
55
|
+
assert_equal 'MultiArray(OBJECT,3,2)', M( O, 3, 2 ).inspect
|
37
56
|
end
|
38
57
|
|
39
58
|
def test_multiarray_to_s
|
40
|
-
assert_equal 'MultiArray
|
59
|
+
assert_equal 'MultiArray(OBJECT,3,2)', M( O, 3, 2 ).to_s
|
60
|
+
end
|
61
|
+
|
62
|
+
def test_multiarray_default
|
63
|
+
assert_equal [ [ O.default ] * 3 ] * 2, M( O, 3, 2 ).default.to_a
|
64
|
+
end
|
65
|
+
|
66
|
+
def test_multiarray_at
|
67
|
+
assert_equal [ [ 1, 2, 3 ], [ 4, 5, 6 ] ],
|
68
|
+
M[ [ 1, 2, 3 ], [ 4, 5, 6 ] ].to_a
|
69
|
+
assert_equal O, M[ [ :a ] ].typecode
|
70
|
+
assert_equal B, M[ [ false ], [ true ] ].typecode
|
71
|
+
assert_equal I, M[ [ -2 ** 31, 2 ** 31 - 1 ] ].typecode
|
41
72
|
end
|
42
73
|
|
43
|
-
def
|
44
|
-
assert_equal
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
assert_equal
|
49
|
-
|
74
|
+
def test_multiarray_typecode
|
75
|
+
assert_equal O, M( O, 3, 2 ).typecode
|
76
|
+
end
|
77
|
+
|
78
|
+
def test_multiarray_dimension
|
79
|
+
assert_equal 2, M( O, 3, 2 ).dimension
|
80
|
+
end
|
81
|
+
|
82
|
+
def test_multiarray_shape
|
83
|
+
assert_equal [ 3, 2 ], M( O, 3, 2 ).shape
|
50
84
|
end
|
51
85
|
|
52
86
|
def test_inspect
|
53
|
-
assert_equal "MultiArray
|
54
|
-
|
55
|
-
M[ [ :a, :b, :c ], [ :d, :e, :f ] ].inspect
|
87
|
+
assert_equal "MultiArray(OBJECT,3,2):\n[ [ :a, 2, 3 ],\n [ 4, 5, 6 ] ]",
|
88
|
+
M[ [ :a, 2, 3 ], [ 4, 5, 6 ] ].inspect
|
56
89
|
end
|
57
90
|
|
58
|
-
def
|
59
|
-
|
91
|
+
def test_typecode
|
92
|
+
assert_equal O, M( O, 3, 2 ).new.typecode
|
93
|
+
end
|
94
|
+
|
95
|
+
def test_dimension
|
96
|
+
assert_equal 2, M( O, 3, 2 ).new.dimension
|
97
|
+
end
|
98
|
+
|
99
|
+
def test_shape
|
100
|
+
assert_equal [ 3, 2 ], M( O, 3, 2 ).new.shape
|
60
101
|
end
|
61
102
|
|
62
103
|
def test_at_assign
|
63
104
|
m = M.new O, 3, 2
|
64
105
|
for j in 0 ... 2
|
65
106
|
for i in 0 ... 3
|
66
|
-
assert_equal
|
107
|
+
assert_equal j * 3 + i + 1, m[ j ][ i ] = j * 3 + i + 1
|
108
|
+
assert_equal j * 3 + i + 1, m[ i, j ] = j * 3 + i + 1
|
67
109
|
end
|
68
110
|
end
|
69
111
|
for j in 0 ... 2
|
70
112
|
for i in 0 ... 3
|
71
|
-
assert_equal
|
113
|
+
assert_equal j * 3 + i + 1, m[ j ][ i ]
|
114
|
+
assert_equal j * 3 + i + 1, m[ i, j ]
|
72
115
|
end
|
73
116
|
end
|
74
|
-
assert_equal [ 4, 5, 6 ], m[ 1 ].to_a
|
75
|
-
assert_equal 7, m[ 1 ] = 7
|
76
|
-
assert_equal [ [ 1, 2, 3 ], [ 7, 7, 7 ] ], m.to_a
|
77
117
|
end
|
78
118
|
|
79
119
|
def test_equal
|
120
|
+
assert_equal M[ [ 1, 2, 3 ], [ 4, 5, 6 ] ], M[ [ 1, 2, 3 ], [ 4, 5, 6 ] ]
|
121
|
+
assert_not_equal M[ [ 1, 2, 3 ], [ 4, 5, 6 ] ],
|
122
|
+
M[ [ 1, 2, 3 ], [ 4, 6, 5 ] ]
|
80
123
|
# !!!
|
124
|
+
assert_not_equal M[ [ 1, 1 ], [ 1, 1 ] ], 1
|
125
|
+
assert_not_equal M[ [ 1, 1 ], [ 1, 1 ] ], S[ 1, 1 ]
|
126
|
+
end
|
127
|
+
|
128
|
+
def test_inject
|
129
|
+
assert_equal 21, M[ [ 1, 2, 3 ], [ 4, 5, 6 ] ].inject { |a,b| a + b }
|
130
|
+
assert_equal 28, M[ [ 1, 2, 3 ], [ 4, 5, 6 ] ].inject( 7 ) { |a,b| a + b }
|
131
|
+
end
|
132
|
+
|
133
|
+
def test_sum
|
134
|
+
m = M[ [ 1, 2, 3 ], [ 4, 5, 6 ] ]
|
135
|
+
assert_equal 21, sum { |i,j| m[ i, j ] }
|
136
|
+
assert_equal [ 5, 7, 9 ], sum { |i| m[ i ] }.to_a
|
137
|
+
assert_equal [ 6, 15 ], eager { |j| sum { |i| m[ i, j ] } }.to_a
|
138
|
+
assert_equal [ [ 1, 2, 3 ] , [ 4, 5, 6 ] ], sum { || m }.to_a
|
139
|
+
end
|
140
|
+
|
141
|
+
def dont_test_convolve
|
142
|
+
f = M[ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7, 8, 9 ] ]
|
143
|
+
assert_equal M[ [ 5, 6, 0 ], [ 8, 9, 0 ], [ 0, 0, 0 ] ],
|
144
|
+
M[ [ 1, 0, 0 ], [ 0, 0, 0 ], [ 0, 0, 0 ] ].convolve( f )
|
145
|
+
assert_equal M[ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7, 8, 9 ] ],
|
146
|
+
M[ [ 0, 0, 0 ], [ 0, 1, 0 ], [ 0, 0, 0 ] ].convolve( f )
|
147
|
+
assert_equal M[ [ 0, 0, 0 ], [ 1, 2, 3 ], [ 4, 5, 6 ] ],
|
148
|
+
M[ [ 0, 0, 0 ], [ 0, 0, 0 ], [ 0, 1, 0 ] ].convolve( f )
|
149
|
+
end
|
150
|
+
|
151
|
+
def test_zero
|
152
|
+
assert_equal M[ [ false, true ], [ true, false ] ],
|
153
|
+
M[ [ -1, 0 ], [ 0, 1 ] ].zero?
|
154
|
+
end
|
155
|
+
|
156
|
+
def test_nonzero
|
157
|
+
assert_equal M[ [ true, false ], [ false, true ] ],
|
158
|
+
M[ [ -1, 0 ], [ 0, 1 ] ].nonzero?
|
159
|
+
end
|
160
|
+
|
161
|
+
def test_not
|
162
|
+
assert_equal [ [ true, false ], [ false, true ] ],
|
163
|
+
M[ [ false, true ], [ true, false ] ].not.to_a
|
164
|
+
assert_equal [ [ true, false ], [ false, true ] ],
|
165
|
+
M[ [ 0, 1 ], [ 2, 0 ] ].not.to_a
|
166
|
+
end
|
167
|
+
|
168
|
+
def test_and
|
169
|
+
assert_equal [ [ false, false ] ], M[ [ false, true ] ].and( false ).to_a
|
170
|
+
assert_equal [ [ false, false ] ], false.and( M[ [ false, true ] ] ).to_a
|
171
|
+
assert_equal [ [ false, true ] ], M[ [ false, true ] ].and( true ).to_a
|
172
|
+
assert_equal [ [ false, true ] ], true.and( M[ [ false, true ] ] ).to_a
|
173
|
+
assert_equal [ [ false, false ], [ false, true ] ],
|
174
|
+
M[ [ false, true ], [ false, true ] ].
|
175
|
+
and( M[ [ false, false ], [ true, true ] ] ).to_a
|
176
|
+
assert_equal [ [ false, false ], [ true, false ] ],
|
177
|
+
M[ [ false, true ], [ true, false ] ].
|
178
|
+
and( S[ false, true ] ).to_a
|
179
|
+
end
|
180
|
+
|
181
|
+
def test_or
|
182
|
+
assert_equal [ [ false, true ] ], M[ [ false, true ] ].or( false ).to_a
|
183
|
+
assert_equal [ [ false, true ] ], false.or( M[ [ false, true ] ] ).to_a
|
184
|
+
assert_equal [ [ true, true ] ], M[ [ false, true ] ].or( true ).to_a
|
185
|
+
assert_equal [ [ true, true ] ], true.or( M[ [ false, true ] ] ).to_a
|
186
|
+
assert_equal [ [ false, true ], [ true, true ] ],
|
187
|
+
M[ [ false, true ], [ false, true ] ].
|
188
|
+
or( M[ [ false, false ], [ true, true ] ] ).to_a
|
189
|
+
assert_equal [ [ false, true ], [ true, true ] ],
|
190
|
+
M[ [ false, true ], [ true, false ] ].
|
191
|
+
or( S[ false, true ] ).to_a
|
192
|
+
end
|
193
|
+
|
194
|
+
def test_bitwise_not
|
195
|
+
assert_equal [ [ 255, 254 ], [ 253, 252 ] ],
|
196
|
+
( ~M[ [ 0, 1 ], [ 2, 3 ] ] ).to_a
|
197
|
+
assert_equal [ [ 0, -1 ], [ -2, -3 ] ],
|
198
|
+
( ~M[ [ -1, 0 ], [ 1, 2 ] ] ).to_a
|
199
|
+
end
|
200
|
+
|
201
|
+
def test_bitwise_and
|
202
|
+
assert_equal [ [ 0, 1 ], [ 0, 1 ] ], ( M[ [ 0, 1 ], [ 2, 3 ] ] & 1 ).to_a
|
203
|
+
assert_equal [ [ 0, 1 ], [ 0, 1 ] ], ( 1 & M[ [ 0, 1 ], [ 2, 3 ] ] ).to_a
|
204
|
+
assert_equal [ [ 0, 1 ], [ 0, 2 ] ], ( M[ [ 0, 1 ], [ 2, 3 ] ] &
|
205
|
+
M[ [ 4, 3 ], [ 1, 2 ] ] ).to_a
|
206
|
+
end
|
207
|
+
|
208
|
+
def test_bitwise_or
|
209
|
+
assert_equal [ [ 1, 1 ], [ 3, 3 ] ], ( M[ [ 0, 1 ], [ 2, 3 ] ] | 1 ).to_a
|
210
|
+
assert_equal [ [ 1, 1 ], [ 3, 3 ] ], ( 1 | M[ [ 0, 1 ], [ 2, 3 ] ] ).to_a
|
211
|
+
assert_equal [ [ 4, 3 ], [ 3, 3 ] ], ( M[ [ 0, 1 ], [ 2, 3 ] ] |
|
212
|
+
M[ [ 4, 3 ], [ 1, 2 ] ] ).to_a
|
213
|
+
end
|
214
|
+
|
215
|
+
def test_bitwise_xor
|
216
|
+
assert_equal [ [ 1, 0 ], [ 3, 2 ] ], ( M[ [ 0, 1 ], [ 2, 3 ] ] ^ 1 ).to_a
|
217
|
+
assert_equal [ [ 1, 0 ], [ 3, 2 ] ], ( 1 ^ M[ [ 0, 1 ], [ 2, 3 ] ] ).to_a
|
218
|
+
assert_equal [ [ 4, 2 ], [ 3, 1 ] ], ( M[ [ 0, 1 ], [ 2, 3 ] ] ^
|
219
|
+
M[ [ 4, 3 ], [ 1, 2 ] ] ).to_a
|
220
|
+
end
|
221
|
+
|
222
|
+
def test_shl
|
223
|
+
assert_equal [ [ 2, 4 ], [ 6, 8 ] ], ( M[ [ 1, 2 ], [ 3, 4 ] ] << 1 ).to_a
|
224
|
+
assert_equal [ [ 6, 12 ], [ 24, 48 ] ],
|
225
|
+
( 3 << M[ [ 1, 2 ], [ 3, 4 ] ] ).to_a
|
226
|
+
assert_equal [ [ 8, 8 ], [ 6, 4 ] ],
|
227
|
+
( M[ [ 1, 2 ], [ 3, 4 ] ] << M[ [ 3, 2 ], [ 1, 0 ] ] ).to_a
|
228
|
+
end
|
229
|
+
|
230
|
+
def test_shr
|
231
|
+
assert_equal [ [ 1, 2 ], [ 3, 4 ] ], ( M[ [ 2, 4 ], [ 6, 8 ] ] >> 1 ).to_a
|
232
|
+
assert_equal [ [ 24, 12 ], [ 6, 3 ] ],
|
233
|
+
( 48 >> M[ [ 1, 2 ], [ 3, 4 ] ] ).to_a
|
234
|
+
assert_equal [ [ 2, 1 ], [ 3, 2 ] ],
|
235
|
+
( M[ [ 16, 4 ], [ 6, 2 ] ] >> M[ [ 3, 2 ], [ 1, 0 ] ] ).to_a
|
81
236
|
end
|
82
237
|
|
83
238
|
def test_negate
|
84
|
-
|
85
|
-
|
86
|
-
end
|
87
|
-
|
88
|
-
def
|
89
|
-
|
90
|
-
|
91
|
-
assert_equal
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
u = -lazy { -m }
|
97
|
-
assert_equal "MultiArray.object(3,2):\n[ [ 1, 2, 3 ],\n [ 4, 5, 6 ] ]",
|
98
|
-
u.inspect
|
99
|
-
assert_equal [ [ 1, 2, 3 ], [ 4, 5, 6 ] ], u.to_a
|
100
|
-
u = lazy { -lazy { -m } }
|
101
|
-
assert_equal 'MultiArray.object(3,2):<delayed>', u.inspect
|
102
|
-
assert_equal [ [ 1, 2, 3 ], [ 4, 5, 6 ] ], u.force.to_a
|
103
|
-
u = eager { lazy { -m } }
|
104
|
-
assert_equal 'MultiArray.object(3,2):<delayed>', u.inspect
|
105
|
-
assert_equal [ [ -1, -2, -3 ], [ -4, -5, -6 ] ], u.force.to_a
|
106
|
-
u = lazy { eager { -lazy { -m } } }
|
107
|
-
assert_equal "MultiArray.object(3,2):\n[ [ 1, 2, 3 ],\n [ 4, 5, 6 ] ]",
|
108
|
-
u.inspect
|
109
|
-
assert_equal [ [ 1, 2, 3 ], [ 4, 5, 6 ] ], u.to_a
|
239
|
+
assert_equal M[ [ -1, 2, -3 ], [ 4, -5, 6 ] ],
|
240
|
+
-M[ [ 1, -2, 3 ], [ -4, 5, -6 ] ]
|
241
|
+
end
|
242
|
+
|
243
|
+
def test_plus
|
244
|
+
assert_equal M[ [ 2, 3, 5 ], [ 3, 5, 7 ] ],
|
245
|
+
M[ [ 1, 2, 4 ], [ 2, 4, 6 ] ] + 1
|
246
|
+
assert_equal M[ [ 2, 3, 5 ], [ 3, 5, 7 ] ],
|
247
|
+
1 + M[ [ 1, 2, 4 ], [ 2, 4, 6 ] ]
|
248
|
+
assert_equal M[ [ -3, 2, 1 ], [ 8, 6, 4 ] ] +
|
249
|
+
M[ [ 2, 0, 2 ], [ -4, -1, 2 ] ],
|
250
|
+
M[ [ -1, 2, 3 ], [ 4, 5, 6 ] ]
|
110
251
|
end
|
111
252
|
|
112
253
|
end
|
data/test/tc_object.rb
CHANGED
@@ -1,3 +1,19 @@
|
|
1
|
+
# multiarray - Lazy multi-dimensional arrays for Ruby
|
2
|
+
# Copyright (C) 2010 Jan Wedekind
|
3
|
+
#
|
4
|
+
# This program is free software: you can redistribute it and/or modify
|
5
|
+
# it under the terms of the GNU General Public License as published by
|
6
|
+
# the Free Software Foundation, either version 3 of the License, or
|
7
|
+
# (at your option) any later version.
|
8
|
+
#
|
9
|
+
# This program is distributed in the hope that it will be useful,
|
10
|
+
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
11
|
+
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
12
|
+
# GNU General Public License for more details.
|
13
|
+
#
|
14
|
+
# You should have received a copy of the GNU General Public License
|
15
|
+
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
16
|
+
|
1
17
|
require 'test/unit'
|
2
18
|
begin
|
3
19
|
require 'rubygems'
|
@@ -9,44 +25,56 @@ class TC_Object < Test::Unit::TestCase
|
|
9
25
|
|
10
26
|
O = Hornetseye::OBJECT
|
11
27
|
|
12
|
-
def
|
13
|
-
Hornetseye::lazy &action
|
28
|
+
def setup
|
14
29
|
end
|
15
30
|
|
16
|
-
def
|
17
|
-
Hornetseye::eager &action
|
31
|
+
def teardown
|
18
32
|
end
|
19
33
|
|
20
|
-
def
|
34
|
+
def test_object_inspect
|
35
|
+
assert_equal 'OBJECT', O.inspect
|
21
36
|
end
|
22
37
|
|
23
|
-
def
|
38
|
+
def test_object_to_s
|
39
|
+
assert_equal 'OBJECT', O.to_s
|
24
40
|
end
|
25
41
|
|
26
42
|
def test_object_default
|
27
43
|
assert_nil O.new[]
|
28
44
|
end
|
29
45
|
|
30
|
-
def
|
31
|
-
assert_equal
|
46
|
+
def test_object_typecode
|
47
|
+
assert_equal O, O.typecode
|
32
48
|
end
|
33
49
|
|
34
|
-
def
|
35
|
-
assert_equal
|
50
|
+
def test_object_dimension
|
51
|
+
assert_equal 0, O.dimension
|
36
52
|
end
|
37
53
|
|
38
|
-
def
|
39
|
-
assert_equal
|
54
|
+
def test_object_shape
|
55
|
+
assert_equal [], O.shape
|
40
56
|
end
|
41
57
|
|
42
|
-
def
|
43
|
-
assert_equal '42', O.new( 42 ).
|
58
|
+
def test_inspect
|
59
|
+
assert_equal 'OBJECT(42)', O.new( 42 ).inspect
|
44
60
|
end
|
45
61
|
|
46
62
|
def test_marshal
|
47
63
|
assert_equal O.new( 42 ), Marshal.load( Marshal.dump( O.new( 42 ) ) )
|
48
64
|
end
|
49
65
|
|
66
|
+
def test_typecode
|
67
|
+
assert_equal O, O.new.typecode
|
68
|
+
end
|
69
|
+
|
70
|
+
def test_dimension
|
71
|
+
assert_equal 0, O.new.dimension
|
72
|
+
end
|
73
|
+
|
74
|
+
def test_shape
|
75
|
+
assert_equal [], O.new.shape
|
76
|
+
end
|
77
|
+
|
50
78
|
def test_at_assign
|
51
79
|
o = O.new 3
|
52
80
|
assert_equal 3, o[]
|
@@ -59,45 +87,22 @@ class TC_Object < Test::Unit::TestCase
|
|
59
87
|
assert_equal O.new( 3 ), O.new( 3 )
|
60
88
|
end
|
61
89
|
|
90
|
+
def test_inject
|
91
|
+
assert_equal 2, O.new( 2 ).inject { |a,b| a + b }[]
|
92
|
+
assert_equal 3, O.new( 2 ).inject( 1 ) { |a,b| a + b }[]
|
93
|
+
end
|
94
|
+
|
95
|
+
def test_zero
|
96
|
+
assert O.new( 0 ).zero?[]
|
97
|
+
assert !O.new( 3 ).zero?[]
|
98
|
+
end
|
99
|
+
|
62
100
|
def test_negate
|
63
|
-
|
64
|
-
assert_equal O.new( -5 ), -o
|
101
|
+
assert_equal O.new( -5 ), -O.new( 5 )
|
65
102
|
end
|
66
103
|
|
67
104
|
def test_plus
|
68
|
-
|
69
|
-
w = O.new 5
|
70
|
-
assert_equal O.new( 3 + 5 ), v + w
|
71
|
-
end
|
72
|
-
|
73
|
-
def test_lazy_unary
|
74
|
-
o = lazy { -O.new( 3 ) }
|
75
|
-
assert_not_equal O.new( -3 ), o
|
76
|
-
assert_equal 'OBJECT(<delayed>)', o.inspect
|
77
|
-
assert_equal O.new( -3 ), o.force
|
78
|
-
o = lazy { --O.new( 3 ) }
|
79
|
-
assert_equal 'OBJECT(<delayed>)', o.inspect
|
80
|
-
assert_equal O.new( 3 ), o.force
|
81
|
-
o = -lazy { -O.new( 3 ) }
|
82
|
-
assert_equal O.new( 3 ), o
|
83
|
-
o = lazy { -lazy { -O.new( 3 ) } }
|
84
|
-
assert_equal 'OBJECT(<delayed>)', o.inspect
|
85
|
-
assert_equal O.new( 3 ), o.force
|
86
|
-
o = eager { lazy { -O.new( 3 ) } }
|
87
|
-
assert_equal 'OBJECT(<delayed>)', o.inspect
|
88
|
-
o = lazy { eager { -lazy { -O.new( 3 ) } } }
|
89
|
-
assert_equal O.new( 3 ), o
|
90
|
-
end
|
91
|
-
|
92
|
-
def test_lazy_binary
|
93
|
-
v = O.new 3
|
94
|
-
w = O.new 5
|
95
|
-
o = lazy { v + w }
|
96
|
-
assert_not_equal v + w, o
|
97
|
-
assert_equal 'OBJECT(<delayed>)', o.inspect
|
98
|
-
assert_equal O.new( 8 ), o.force
|
99
|
-
assert_equal O.new( 9 ), o + O.new( 1 )
|
100
|
-
assert_equal O.new( 9 ), O.new( 1 ) + o
|
105
|
+
assert_equal O.new( 3 + 5 ), O.new( 3 ) + O.new( 5 )
|
101
106
|
end
|
102
107
|
|
103
108
|
end
|