nmatrix 0.0.8 → 0.0.9
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.
- checksums.yaml +4 -4
- data/.gitignore +3 -8
- data/.rspec +1 -1
- data/.travis.yml +12 -0
- data/CONTRIBUTING.md +27 -12
- data/Gemfile +1 -0
- data/History.txt +38 -0
- data/Manifest.txt +15 -15
- data/README.rdoc +7 -6
- data/Rakefile +40 -5
- data/ext/nmatrix/data/data.cpp +2 -37
- data/ext/nmatrix/data/data.h +19 -121
- data/ext/nmatrix/data/meta.h +70 -0
- data/ext/nmatrix/extconf.rb +40 -12
- data/ext/nmatrix/math/math.h +13 -103
- data/ext/nmatrix/nmatrix.cpp +10 -2018
- data/ext/nmatrix/nmatrix.h +16 -13
- data/ext/nmatrix/ruby_constants.cpp +12 -1
- data/ext/nmatrix/ruby_constants.h +7 -1
- data/ext/nmatrix/ruby_nmatrix.c +2169 -0
- data/ext/nmatrix/storage/dense.cpp +123 -14
- data/ext/nmatrix/storage/dense.h +10 -4
- data/ext/nmatrix/storage/list.cpp +265 -48
- data/ext/nmatrix/storage/list.h +6 -9
- data/ext/nmatrix/storage/storage.cpp +44 -54
- data/ext/nmatrix/storage/storage.h +2 -2
- data/ext/nmatrix/storage/yale/class.h +1070 -0
- data/ext/nmatrix/storage/yale/iterators/base.h +142 -0
- data/ext/nmatrix/storage/yale/iterators/iterator.h +130 -0
- data/ext/nmatrix/storage/yale/iterators/row.h +449 -0
- data/ext/nmatrix/storage/yale/iterators/row_stored.h +139 -0
- data/ext/nmatrix/storage/yale/iterators/row_stored_nd.h +167 -0
- data/ext/nmatrix/storage/yale/iterators/stored_diagonal.h +123 -0
- data/ext/nmatrix/storage/yale/math/transpose.h +110 -0
- data/ext/nmatrix/storage/yale/yale.cpp +1785 -0
- data/ext/nmatrix/storage/{yale.h → yale/yale.h} +23 -55
- data/ext/nmatrix/types.h +2 -0
- data/ext/nmatrix/util/io.cpp +27 -45
- data/ext/nmatrix/util/io.h +0 -2
- data/ext/nmatrix/util/sl_list.cpp +169 -28
- data/ext/nmatrix/util/sl_list.h +9 -3
- data/lib/nmatrix/blas.rb +20 -20
- data/lib/nmatrix/enumerate.rb +1 -1
- data/lib/nmatrix/io/mat5_reader.rb +8 -14
- data/lib/nmatrix/lapack.rb +3 -3
- data/lib/nmatrix/math.rb +3 -3
- data/lib/nmatrix/nmatrix.rb +19 -5
- data/lib/nmatrix/nvector.rb +2 -0
- data/lib/nmatrix/shortcuts.rb +90 -125
- data/lib/nmatrix/version.rb +1 -1
- data/nmatrix.gemspec +7 -8
- data/spec/{nmatrix_spec.rb → 00_nmatrix_spec.rb} +45 -208
- data/spec/01_enum_spec.rb +184 -0
- data/spec/{slice_spec.rb → 02_slice_spec.rb} +55 -39
- data/spec/blas_spec.rb +22 -54
- data/spec/elementwise_spec.rb +9 -8
- data/spec/io_spec.rb +6 -4
- data/spec/lapack_spec.rb +26 -26
- data/spec/math_spec.rb +9 -5
- data/spec/nmatrix_yale_spec.rb +29 -61
- data/spec/shortcuts_spec.rb +34 -22
- data/spec/slice_set_spec.rb +157 -0
- data/spec/spec_helper.rb +42 -2
- data/spec/stat_spec.rb +192 -0
- metadata +52 -55
- data/ext/nmatrix/storage/yale.cpp +0 -2284
- data/spec/nmatrix_list_spec.rb +0 -113
- data/spec/nvector_spec.rb +0 -112
data/ext/nmatrix/util/sl_list.h
CHANGED
@@ -78,10 +78,15 @@ void mark(LIST* list, size_t recursions);
|
|
78
78
|
///////////////
|
79
79
|
|
80
80
|
NODE* insert(LIST* list, bool replace, size_t key, void* val);
|
81
|
-
NODE*
|
81
|
+
NODE* insert_copy(LIST *list, bool replace, size_t key, void *val, size_t size);
|
82
|
+
NODE* insert_first_node(LIST* list, size_t key, void* val, size_t val_size);
|
83
|
+
NODE* insert_first_list(LIST* list, size_t key, LIST* l);
|
82
84
|
NODE* insert_after(NODE* node, size_t key, void* val);
|
85
|
+
NODE* replace_insert_after(NODE* node, size_t key, void* val, bool copy, size_t copy_size);
|
83
86
|
void* remove(LIST* list, size_t key);
|
84
|
-
|
87
|
+
void* remove_by_node(LIST* list, NODE* prev, NODE* rm);
|
88
|
+
bool remove_recursive(LIST* list, const size_t* coords, const size_t* offset, const size_t* lengths, size_t r, const size_t& dim);
|
89
|
+
bool node_is_within_slice(NODE* n, size_t coord, size_t len);
|
85
90
|
|
86
91
|
template <typename Type>
|
87
92
|
inline NODE* insert_helper(LIST* list, NODE* node, size_t key, Type val) {
|
@@ -116,7 +121,8 @@ inline NODE* insert_helper(LIST* list, NODE* node, size_t key, Type* ptr) {
|
|
116
121
|
/////////////
|
117
122
|
|
118
123
|
NODE* find(LIST* list, size_t key);
|
119
|
-
NODE*
|
124
|
+
NODE* find_preceding_from_node(NODE* prev, size_t key);
|
125
|
+
NODE* find_preceding_from_list(LIST* l, size_t key);
|
120
126
|
NODE* find_nearest(LIST* list, size_t key);
|
121
127
|
NODE* find_nearest_from(NODE* prev, size_t key);
|
122
128
|
|
data/lib/nmatrix/blas.rb
CHANGED
@@ -85,7 +85,7 @@ module NMatrix::BLAS
|
|
85
85
|
end
|
86
86
|
|
87
87
|
n ||= transpose_b ? b.shape[0] : b.shape[1]
|
88
|
-
c = NMatrix.new([m, n], a.dtype)
|
88
|
+
c = NMatrix.new([m, n], dtype: a.dtype)
|
89
89
|
end
|
90
90
|
|
91
91
|
# I think these are independent of whether or not a transpose occurs.
|
@@ -107,9 +107,9 @@ module NMatrix::BLAS
|
|
107
107
|
|
108
108
|
#
|
109
109
|
# call-seq:
|
110
|
-
# gemv(a, x) ->
|
111
|
-
# gemv(a, x, y) ->
|
112
|
-
# gemv(a, x, y, alpha, beta) ->
|
110
|
+
# gemv(a, x) -> NMatrix
|
111
|
+
# gemv(a, x, y) -> NMatrix
|
112
|
+
# gemv(a, x, y, alpha, beta) -> NMatrix
|
113
113
|
#
|
114
114
|
# Implements matrix-vector product via
|
115
115
|
# y = (alpha * A * x) + (beta * y)
|
@@ -150,7 +150,7 @@ module NMatrix::BLAS
|
|
150
150
|
beta = Complex(0.0, 0.0) if beta == 0.0
|
151
151
|
end
|
152
152
|
|
153
|
-
y ||= NMatrix.new([m, n], a.dtype)
|
153
|
+
y ||= NMatrix.new([m, n], dtype: a.dtype)
|
154
154
|
|
155
155
|
::NMatrix::BLAS.cblas_gemv(transpose_a, m, n, alpha, a, lda, x, incx, beta, y, incy)
|
156
156
|
|
@@ -159,29 +159,29 @@ module NMatrix::BLAS
|
|
159
159
|
|
160
160
|
#
|
161
161
|
# call-seq:
|
162
|
-
# rot(x, y, c, s) -> [
|
162
|
+
# rot(x, y, c, s) -> [NMatrix, NMatrix]
|
163
163
|
#
|
164
164
|
# Apply plane rotation.
|
165
165
|
#
|
166
166
|
# * *Arguments* :
|
167
|
-
# - +x+ ->
|
168
|
-
# - +y+ ->
|
167
|
+
# - +x+ -> NMatrix
|
168
|
+
# - +y+ -> NMatrix
|
169
169
|
# - +c+ -> cosine of the angle of rotation
|
170
170
|
# - +s+ -> sine of the angle of rotation
|
171
|
-
# - +incx+ -> stride of
|
172
|
-
# - +incy+ -> stride of
|
171
|
+
# - +incx+ -> stride of NMatrix +x+
|
172
|
+
# - +incy+ -> stride of NMatrix +y+
|
173
173
|
# - +n+ -> number of elements to consider in x and y
|
174
174
|
# - +in_place+ -> true if it's okay to modify the supplied +x+ and +y+ parameters directly; false if not. Default is false.
|
175
175
|
# * *Returns* :
|
176
176
|
# - Array with the results, in the format [xx, yy]
|
177
177
|
# * *Raises* :
|
178
|
-
# - +ArgumentError+ -> Expected dense
|
178
|
+
# - +ArgumentError+ -> Expected dense NMatrices as first two arguments.
|
179
179
|
# - +ArgumentError+ -> NMatrix dtype mismatch.
|
180
180
|
# - +ArgumentError+ -> Need to supply n for non-standard incx, incy values.
|
181
181
|
#
|
182
182
|
def rot(x, y, c, s, incx = 1, incy = 1, n = nil, in_place=false)
|
183
|
-
raise(ArgumentError, 'Expected dense NMatrices as first two arguments.')
|
184
|
-
raise(ArgumentError, 'NMatrix dtype mismatch.')
|
183
|
+
raise(ArgumentError, 'Expected dense NMatrices as first two arguments.') unless x.is_a?(NMatrix) and y.is_a?(NMatrix) and x.stype == :dense and y.stype == :dense
|
184
|
+
raise(ArgumentError, 'NMatrix dtype mismatch.') unless x.dtype == y.dtype
|
185
185
|
raise(ArgumentError, 'Need to supply n for non-standard incx, incy values') if n.nil? && incx != 1 && incx != -1 && incy != 1 && incy != -1
|
186
186
|
|
187
187
|
n ||= [x.size/incx.abs, y.size/incy.abs].min
|
@@ -202,7 +202,7 @@ module NMatrix::BLAS
|
|
202
202
|
|
203
203
|
#
|
204
204
|
# call-seq:
|
205
|
-
# rot!(x, y, c, s) -> [
|
205
|
+
# rot!(x, y, c, s) -> [NMatrix, NMatrix]
|
206
206
|
#
|
207
207
|
# Apply plane rotation directly to +x+ and +y+.
|
208
208
|
#
|
@@ -221,11 +221,11 @@ module NMatrix::BLAS
|
|
221
221
|
# Since the givens rotation includes a square root, integers and rationals are disallowed.
|
222
222
|
#
|
223
223
|
# * *Arguments* :
|
224
|
-
# - +ab+ ->
|
224
|
+
# - +ab+ -> NMatrix with two elements
|
225
225
|
# * *Returns* :
|
226
226
|
# - Array with the results, in the format [cos(theta), sin(theta)]
|
227
227
|
# * *Raises* :
|
228
|
-
# - +ArgumentError+ -> Expected dense
|
228
|
+
# - +ArgumentError+ -> Expected dense NMatrix of size 2
|
229
229
|
#
|
230
230
|
def rotg(ab)
|
231
231
|
raise(ArgumentError, "Expected dense NMatrix of shape [2,1] or [1,2]") unless ab.is_a?(NMatrix) && ab.stype == :dense && ab.size == 2
|
@@ -241,13 +241,13 @@ module NMatrix::BLAS
|
|
241
241
|
# Calculate the sum of absolute values of the entries of a vector +x+ of size +n+
|
242
242
|
#
|
243
243
|
# * *Arguments* :
|
244
|
-
# - +x+ -> an
|
244
|
+
# - +x+ -> an NMatrix (will also allow an NMatrix, but will treat it as if it's a vector )
|
245
245
|
# - +incx+ -> the skip size (defaults to 1)
|
246
246
|
# - +n+ -> the size of +x+ (defaults to +x.size / incx+)
|
247
247
|
# * *Returns* :
|
248
248
|
# - The sum
|
249
249
|
# * *Raises* :
|
250
|
-
# - +ArgumentError+ -> Expected dense
|
250
|
+
# - +ArgumentError+ -> Expected dense NMatrix for arg 0
|
251
251
|
# - +RangeError+ -> n out of range
|
252
252
|
#
|
253
253
|
def asum(x, incx = 1, n = nil)
|
@@ -264,13 +264,13 @@ module NMatrix::BLAS
|
|
264
264
|
# Calculate the 2-norm of a vector +x+ of size +n+
|
265
265
|
#
|
266
266
|
# * *Arguments* :
|
267
|
-
# - +x+ -> an
|
267
|
+
# - +x+ -> an NMatrix (will also allow an NMatrix, but will treat it as if it's a vector )
|
268
268
|
# - +incx+ -> the skip size (defaults to 1)
|
269
269
|
# - +n+ -> the size of +x+ (defaults to +x.size / incx+)
|
270
270
|
# * *Returns* :
|
271
271
|
# - The 2-norm
|
272
272
|
# * *Raises* :
|
273
|
-
# - +ArgumentError+ -> Expected dense
|
273
|
+
# - +ArgumentError+ -> Expected dense NMatrix for arg 0
|
274
274
|
# - +RangeError+ -> n out of range
|
275
275
|
#
|
276
276
|
def nrm2(x, incx = 1, n = nil)
|
data/lib/nmatrix/enumerate.rb
CHANGED
@@ -215,7 +215,7 @@ class NMatrix
|
|
215
215
|
first_as_acc = false
|
216
216
|
|
217
217
|
if initial then
|
218
|
-
acc = NMatrix.new(new_shape, initial, dtype || self.dtype)
|
218
|
+
acc = NMatrix.new(new_shape, initial, :dtype => dtype || self.dtype)
|
219
219
|
else
|
220
220
|
each_rank(dimen) do |sub_mat|
|
221
221
|
acc = (sub_mat.is_a?(NMatrix) and !dtype.nil? and dtype != self.dtype) ? sub_mat.cast(self.stype, dtype) : sub_mat
|
@@ -293,19 +293,16 @@ module NMatrix::IO::Matlab
|
|
293
293
|
|
294
294
|
#
|
295
295
|
# call-seq:
|
296
|
-
# repacked_indices
|
296
|
+
# repacked_indices ->
|
297
297
|
#
|
298
298
|
# Unpacks and repacks index data into the appropriate format for NMatrix.
|
299
299
|
#
|
300
300
|
# If data is already in the appropriate format, does not unpack or
|
301
301
|
# repack, just returns directly.
|
302
302
|
#
|
303
|
-
def repacked_indices
|
304
|
-
|
305
|
-
|
306
|
-
STDERR.puts "indices: Requesting itype #{to_itype.inspect}"
|
307
|
-
repacked_row_indices = ::NMatrix::IO::Matlab.repack( self.row_index.data, :miINT32, :itype => to_itype )
|
308
|
-
repacked_col_indices = ::NMatrix::IO::Matlab.repack( self.column_index.data, :miINT32, :itype => to_itype )
|
303
|
+
def repacked_indices
|
304
|
+
repacked_row_indices = ::NMatrix::IO::Matlab.repack( self.row_index.data, :miINT32, :itype )
|
305
|
+
repacked_col_indices = ::NMatrix::IO::Matlab.repack( self.column_index.data, :miINT32, :itype )
|
309
306
|
|
310
307
|
[repacked_row_indices, repacked_col_indices]
|
311
308
|
end
|
@@ -341,14 +338,11 @@ module NMatrix::IO::Matlab
|
|
341
338
|
when :mxSPARSE
|
342
339
|
raise(NotImplementedError, "expected .mat row indices to be of type :miINT32") unless row_index.tag.data_type == :miINT32
|
343
340
|
raise(NotImplementedError, "expected .mat column indices to be of type :miINT32") unless column_index.tag.data_type == :miINT32
|
344
|
-
|
345
|
-
to_itype = NMatrix.itype_by_shape(dimensions)
|
346
|
-
|
347
341
|
#require 'pry'
|
348
342
|
#binding.pry
|
349
343
|
|
350
344
|
# MATLAB always uses :miINT32 for indices according to the spec
|
351
|
-
ia_ja = repacked_indices
|
345
|
+
ia_ja = repacked_indices
|
352
346
|
data_str, repacked_dtype = repacked_data(dtype)
|
353
347
|
NMatrix.new(:yale, self.dimensions.reverse, repacked_dtype, ia_ja[0], ia_ja[1], data_str, repacked_dtype)
|
354
348
|
|
@@ -443,9 +437,9 @@ module NMatrix::IO::Matlab
|
|
443
437
|
|
444
438
|
FIRST_TAG_FIELD_POS = 128
|
445
439
|
|
446
|
-
|
447
|
-
# Instance Methods #
|
448
|
-
|
440
|
+
###################################
|
441
|
+
# Instance Methods for Mat5Reader #
|
442
|
+
###################################
|
449
443
|
|
450
444
|
def initialize(stream, options = {})
|
451
445
|
super(stream, options)
|
data/lib/nmatrix/lapack.rb
CHANGED
@@ -151,9 +151,9 @@ class NMatrix
|
|
151
151
|
# Build up the u and vt matrices
|
152
152
|
m, n = matrix.shape
|
153
153
|
dtype = matrix.dtype
|
154
|
-
s_matrix = NMatrix.new([1,matrix.shape.min], dtype)
|
155
|
-
u_matrix = NMatrix.new([m,m], dtype)
|
156
|
-
v_matrix = NMatrix.new([n,n], dtype)
|
154
|
+
s_matrix = NMatrix.new([1,matrix.shape.min], dtype: dtype)
|
155
|
+
u_matrix = NMatrix.new([m,m], dtype: dtype)
|
156
|
+
v_matrix = NMatrix.new([n,n], dtype: dtype)
|
157
157
|
# test this
|
158
158
|
s = gesvd(type, matrix, s_matrix, u_matrix, v_matrix)
|
159
159
|
|
data/lib/nmatrix/math.rb
CHANGED
@@ -99,9 +99,9 @@ class NMatrix
|
|
99
99
|
|
100
100
|
def alloc_svd_result
|
101
101
|
[
|
102
|
-
NMatrix.new(
|
103
|
-
NMatrix.new(
|
104
|
-
NMatrix.new(
|
102
|
+
NMatrix.new(self.shape[0], dtype: self.dtype),
|
103
|
+
NMatrix.new([self.shape[0],1], dtype: self.dtype),
|
104
|
+
NMatrix.new(self.shape[1], dtype: self.dtype)
|
105
105
|
]
|
106
106
|
end
|
107
107
|
|
data/lib/nmatrix/nmatrix.rb
CHANGED
@@ -65,6 +65,13 @@ class NMatrix
|
|
65
65
|
def load_file(file_path)
|
66
66
|
NMatrix::IO::Mat5Reader.new(File.open(file_path, 'rb')).to_ruby
|
67
67
|
end
|
68
|
+
|
69
|
+
#
|
70
|
+
# Calculate the size of an NMatrix of a given shape.
|
71
|
+
def size(shape)
|
72
|
+
shape = [shape,shape] unless shape.is_a?(Array)
|
73
|
+
(0...shape.size).inject(1) { |x,i| x * shape[i] }
|
74
|
+
end
|
68
75
|
end
|
69
76
|
|
70
77
|
# TODO: Make this actually pretty.
|
@@ -76,7 +83,7 @@ class NMatrix
|
|
76
83
|
longest = Array.new(self.shape[1], 0)
|
77
84
|
self.each_column.with_index do |col, j|
|
78
85
|
col.each do |elem|
|
79
|
-
elem_len = elem.
|
86
|
+
elem_len = elem.inspect.size
|
80
87
|
longest[j] = elem_len if longest[j] < elem_len
|
81
88
|
end
|
82
89
|
end
|
@@ -87,7 +94,7 @@ class NMatrix
|
|
87
94
|
q.group(0, "\n [\n", " ]\n") do
|
88
95
|
layer.each_row.with_index do |row,i|
|
89
96
|
q.group(0, " [", "]\n") do
|
90
|
-
q.seplist(self[i,0...self.shape[1],k].to_flat_array, lambda { q.text ", "}, :each_with_index) { |v,j| q.text v.
|
97
|
+
q.seplist(self[i,0...self.shape[1],k].to_flat_array, lambda { q.text ", "}, :each_with_index) { |v,j| q.text v.inspect.rjust(longest[j]) }
|
91
98
|
end
|
92
99
|
end
|
93
100
|
end
|
@@ -97,7 +104,7 @@ class NMatrix
|
|
97
104
|
q.group(0, "\n[\n", "]") do
|
98
105
|
self.each_row.with_index do |row,i|
|
99
106
|
q.group(1, " [", "]") do
|
100
|
-
q.seplist(self.dim > 2 ? row.to_a[0] : row.to_a, lambda { q.text ", " }, :each_with_index) { |v,j| q.text v.
|
107
|
+
q.seplist(self.dim > 2 ? row.to_a[0] : row.to_a, lambda { q.text ", " }, :each_with_index) { |v,j| q.text v.inspect.rjust(longest[j]) }
|
101
108
|
end
|
102
109
|
q.breakable
|
103
110
|
end
|
@@ -258,8 +265,7 @@ class NMatrix
|
|
258
265
|
# Returns the total size of the NMatrix based on its shape.
|
259
266
|
#
|
260
267
|
def size
|
261
|
-
|
262
|
-
(0...self.dimensions).inject(1) { |x,i| x * s[i] }
|
268
|
+
NMatrix.size(self.shape)
|
263
269
|
end
|
264
270
|
|
265
271
|
|
@@ -455,6 +461,7 @@ class NMatrix
|
|
455
461
|
#def __list_elementwise_add__ rhs
|
456
462
|
# self.__list_map_merged_stored__(rhs){ |l,r| l+r }.cast(self.stype, NMatrix.upcast(self.dtype, rhs.dtype))
|
457
463
|
#end
|
464
|
+
protected
|
458
465
|
|
459
466
|
def inspect_helper #:nodoc:
|
460
467
|
ary = []
|
@@ -486,6 +493,13 @@ class NMatrix
|
|
486
493
|
end
|
487
494
|
ary
|
488
495
|
end
|
496
|
+
|
497
|
+
|
498
|
+
# NMatrix constructor helper for sparse matrices. Uses multi-slice-setting to initialize a matrix
|
499
|
+
# with a given array of initial values.
|
500
|
+
def __sparse_initial_set__(ary) #:nodoc:
|
501
|
+
self[0...self.shape[0],0...self.shape[1]] = ary
|
502
|
+
end
|
489
503
|
end
|
490
504
|
|
491
505
|
require_relative './shortcuts.rb'
|
data/lib/nmatrix/nvector.rb
CHANGED
data/lib/nmatrix/shortcuts.rb
CHANGED
@@ -70,7 +70,7 @@ class NMatrix
|
|
70
70
|
#
|
71
71
|
# a = NMatrix[ 1,2,3,4 ] => 1.0 2.0 3.0 4.0
|
72
72
|
#
|
73
|
-
# a = NMatrix[ 1,2,3,4, :int32 ] => 1 2 3 4
|
73
|
+
# a = NMatrix[ 1,2,3,4, dtype: :int32 ] => 1 2 3 4
|
74
74
|
#
|
75
75
|
# a = NMatrix[ [1,2,3], [3,4,5] ] => 1.0 2.0 3.0
|
76
76
|
# 3.0 4.0 5.0
|
@@ -85,7 +85,7 @@ class NMatrix
|
|
85
85
|
# Ruby array: a = [ [1,2,3], [4,5,6] ]
|
86
86
|
#
|
87
87
|
def [](*params)
|
88
|
-
|
88
|
+
options = params.last.is_a?(Hash) ? params.pop : {}
|
89
89
|
|
90
90
|
# First find the dimensions of the array.
|
91
91
|
i = 0
|
@@ -101,22 +101,22 @@ class NMatrix
|
|
101
101
|
#shape.unshift(1) if shape.size == 1
|
102
102
|
|
103
103
|
# Then flatten the array.
|
104
|
-
NMatrix.new(shape, params.flatten,
|
104
|
+
NMatrix.new(shape, params.flatten, options)
|
105
105
|
end
|
106
106
|
|
107
107
|
#
|
108
108
|
# call-seq:
|
109
|
-
# zeros(
|
110
|
-
# zeros(
|
111
|
-
# zeros(
|
109
|
+
# zeros(shape) -> NMatrix
|
110
|
+
# zeros(shape, dtype: dtype) -> NMatrix
|
111
|
+
# zeros(shape, dtype: dtype, stype: stype) -> NMatrix
|
112
112
|
#
|
113
113
|
# Creates a new matrix of zeros with the dimensions supplied as
|
114
114
|
# parameters.
|
115
115
|
#
|
116
116
|
# * *Arguments* :
|
117
|
-
# - +
|
118
|
-
# - +size+ -> Array (or integer for square matrix) specifying the dimensions.
|
117
|
+
# - +shape+ -> Array (or integer for square matrix) specifying the dimensions.
|
119
118
|
# - +dtype+ -> (optional) Default is +:float64+
|
119
|
+
# - +stype+ -> (optional) Default is +:dense+.
|
120
120
|
# * *Returns* :
|
121
121
|
# - NMatrix filled with zeros.
|
122
122
|
#
|
@@ -125,30 +125,26 @@ class NMatrix
|
|
125
125
|
# NMatrix.zeros(2) # => 0.0 0.0
|
126
126
|
# 0.0 0.0
|
127
127
|
#
|
128
|
-
# NMatrix.zeros([2, 3], :int32) # => 0 0 0
|
129
|
-
#
|
128
|
+
# NMatrix.zeros([2, 3], dtype: :int32) # => 0 0 0
|
129
|
+
# 0 0 0
|
130
130
|
#
|
131
|
-
# NMatrix.zeros(
|
131
|
+
# NMatrix.zeros([1, 5], dtype: :int32) # => 0 0 0 0 0
|
132
132
|
#
|
133
|
-
def zeros(
|
134
|
-
|
135
|
-
stype = params.first.is_a?(Symbol) ? params.shift : :dense
|
136
|
-
dim = params.first
|
137
|
-
|
138
|
-
NMatrix.new(stype, dim, 0, dtype)
|
133
|
+
def zeros(shape, opts = {})
|
134
|
+
NMatrix.new(shape, 0, {:dtype => :float64}.merge(opts))
|
139
135
|
end
|
140
136
|
alias :zeroes :zeros
|
141
137
|
|
142
138
|
#
|
143
139
|
# call-seq:
|
144
|
-
# ones(
|
145
|
-
# ones(
|
140
|
+
# ones(shape) -> NMatrix
|
141
|
+
# ones(shape, dtype: dtype, stype: stype) -> NMatrix
|
146
142
|
#
|
147
143
|
# Creates a matrix filled with ones.
|
148
144
|
#
|
149
145
|
# * *Arguments* :
|
150
|
-
# - +
|
151
|
-
# - +
|
146
|
+
# - +shape+ -> Array (or integer for square matrix) specifying the shape.
|
147
|
+
# - +opts+ -> (optional) Hash of options from NMatrix#initialize
|
152
148
|
# * *Returns* :
|
153
149
|
# - NMatrix filled with ones.
|
154
150
|
#
|
@@ -156,14 +152,11 @@ class NMatrix
|
|
156
152
|
#
|
157
153
|
# NMatrix.ones([1, 3]) # => 1.0 1.0 1.0
|
158
154
|
#
|
159
|
-
# NMatrix.ones([2, 3], :int32) # => 1 1 1
|
160
|
-
#
|
155
|
+
# NMatrix.ones([2, 3], dtype: :int32) # => 1 1 1
|
156
|
+
# 1 1 1
|
161
157
|
#
|
162
|
-
def ones(
|
163
|
-
|
164
|
-
dim = params.first
|
165
|
-
|
166
|
-
NMatrix.new(dim, 1, dtype)
|
158
|
+
def ones(shape, opts={})
|
159
|
+
NMatrix.new(shape, 1, {:dtype => :float64, :default => 1}.merge(opts))
|
167
160
|
end
|
168
161
|
|
169
162
|
##
|
@@ -177,7 +170,7 @@ class NMatrix
|
|
177
170
|
# @return [NMatrix] a new nmatrix filled with ones.
|
178
171
|
#
|
179
172
|
def ones_like(nm)
|
180
|
-
NMatrix.ones(nm.shape, nm.dtype)
|
173
|
+
NMatrix.ones(nm.shape, dtype: nm.dtype, stype: nm.stype, capacity: nm.capacity, default: 1)
|
181
174
|
end
|
182
175
|
|
183
176
|
##
|
@@ -191,23 +184,23 @@ class NMatrix
|
|
191
184
|
# @return [NMatrix] a new nmatrix filled with zeros.
|
192
185
|
#
|
193
186
|
def zeros_like(nm)
|
194
|
-
NMatrix.zeros(nm.
|
187
|
+
NMatrix.zeros(nm.shape, dtype: nm.dtype, stype: nm.stype, capacity: nm.capacity, default: 0)
|
195
188
|
end
|
196
189
|
|
197
190
|
#
|
198
191
|
# call-seq:
|
199
|
-
# eye(
|
200
|
-
# eye(
|
201
|
-
# eye(
|
192
|
+
# eye(shape) -> NMatrix
|
193
|
+
# eye(shape, dtype: dtype) -> NMatrix
|
194
|
+
# eye(shape, stype: stype, dtype: dtype) -> NMatrix
|
202
195
|
#
|
203
196
|
# Creates an identity matrix (square matrix rank 2).
|
204
197
|
#
|
205
198
|
# * *Arguments* :
|
206
|
-
# - +stype+ -> (optional) Default is +:dense+.
|
207
199
|
# - +size+ -> Array (or integer for square matrix) specifying the dimensions.
|
208
200
|
# - +dtype+ -> (optional) Default is +:float64+
|
201
|
+
# - +stype+ -> (optional) Default is +:dense+.
|
209
202
|
# * *Returns* :
|
210
|
-
# -
|
203
|
+
# - An identity matrix.
|
211
204
|
#
|
212
205
|
# Examples:
|
213
206
|
#
|
@@ -215,22 +208,17 @@ class NMatrix
|
|
215
208
|
# 0.0 1.0 0.0
|
216
209
|
# 0.0 0.0 1.0
|
217
210
|
#
|
218
|
-
# NMatrix.eye(3, :int32) # => 1 0 0
|
219
|
-
#
|
220
|
-
#
|
211
|
+
# NMatrix.eye(3, dtype: :int32) # => 1 0 0
|
212
|
+
# 0 1 0
|
213
|
+
# 0 0 1
|
221
214
|
#
|
222
|
-
# NMatrix.eye(
|
223
|
-
#
|
215
|
+
# NMatrix.eye(2, dtype: :int32, stype: :yale) # => 1 0
|
216
|
+
# 0 1
|
224
217
|
#
|
225
|
-
def eye(
|
226
|
-
dtype = params.last.is_a?(Symbol) ? params.pop : :float64
|
227
|
-
stype = params.first.is_a?(Symbol) ? params.shift : :dense
|
228
|
-
|
229
|
-
dim = params.first
|
230
|
-
|
218
|
+
def eye(shape, opts={})
|
231
219
|
# Fill the diagonal with 1's.
|
232
|
-
m = NMatrix.zeros(
|
233
|
-
(0...
|
220
|
+
m = NMatrix.zeros(shape, {:dtype => :float64}.merge(opts))
|
221
|
+
(0...m.shape[0]).each do |i|
|
234
222
|
m[i, i] = 1
|
235
223
|
end
|
236
224
|
|
@@ -240,16 +228,13 @@ class NMatrix
|
|
240
228
|
#
|
241
229
|
# call-seq:
|
242
230
|
# diagonals(array) -> NMatrix
|
243
|
-
# diagonals(
|
244
|
-
# diagonals(array, dtype) -> NMatrix
|
245
|
-
# diagonals(stype, array) -> NMatrix
|
231
|
+
# diagonals(array, dtype: dtype, stype: stype) -> NMatrix
|
246
232
|
#
|
247
233
|
# Creates a matrix filled with specified diagonals.
|
248
234
|
#
|
249
235
|
# * *Arguments* :
|
250
|
-
# - +stype+ -> (optional) Storage type for the matrix (default is :dense)
|
251
236
|
# - +entries+ -> Array containing input values for diagonal matrix
|
252
|
-
# - +
|
237
|
+
# - +options+ -> (optional) Hash with options for NMatrix#initialize
|
253
238
|
# * *Returns* :
|
254
239
|
# - NMatrix filled with specified diagonal values.
|
255
240
|
#
|
@@ -260,19 +245,17 @@ class NMatrix
|
|
260
245
|
# 0.0 0.0 3.0 0.0
|
261
246
|
# 0.0 0.0 0.0 4.0
|
262
247
|
#
|
263
|
-
# NMatrix.diagonal(
|
264
|
-
#
|
265
|
-
#
|
266
|
-
#
|
248
|
+
# NMatrix.diagonal([1,2,3,4], dtype: :int32) # => 1 0 0 0
|
249
|
+
# 0 2 0 0
|
250
|
+
# 0 0 3 0
|
251
|
+
# 0 0 0 4
|
267
252
|
#
|
268
253
|
#
|
269
|
-
def diagonal(
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
m = NMatrix.zeros(stype, ary.length, dtype || guess_dtype(ary[0]))
|
275
|
-
ary.each_with_index do |n, i|
|
254
|
+
def diagonal(entries, opts={})
|
255
|
+
m = NMatrix.zeros(entries.size,
|
256
|
+
{:dtype => guess_dtype(entries[0]), :capacity => entries.size + 1}.merge(opts)
|
257
|
+
)
|
258
|
+
entries.each_with_index do |n, i|
|
276
259
|
m[i,i] = n
|
277
260
|
end
|
278
261
|
m
|
@@ -282,141 +265,121 @@ class NMatrix
|
|
282
265
|
|
283
266
|
#
|
284
267
|
# call-seq:
|
285
|
-
# random(
|
268
|
+
# random(shape) -> NMatrix
|
286
269
|
#
|
287
270
|
# Creates a +:dense+ NMatrix with random numbers between 0 and 1 generated
|
288
271
|
# by +Random::rand+. The parameter is the dimension of the matrix.
|
289
272
|
#
|
290
273
|
# * *Arguments* :
|
291
|
-
# - +
|
274
|
+
# - +shape+ -> Array (or integer for square matrix) specifying the dimensions.
|
292
275
|
# * *Returns* :
|
293
|
-
# - NMatrix filled with
|
276
|
+
# - NMatrix filled with random values.
|
294
277
|
#
|
295
278
|
# Examples:
|
296
279
|
#
|
297
280
|
# NMatrix.random([2, 2]) # => 0.4859439730644226 0.1783195585012436
|
298
281
|
# 0.23193766176700592 0.4503345191478729
|
299
282
|
#
|
300
|
-
def random(
|
283
|
+
def random(shape, opts={})
|
301
284
|
rng = Random.new
|
302
285
|
|
303
286
|
random_values = []
|
304
287
|
|
305
288
|
# Construct the values of the final matrix based on the dimension.
|
306
|
-
|
307
|
-
(size * size - 1).times { |i| random_values << rng.rand }
|
308
|
-
else
|
309
|
-
# Dimensions given by an array. Get the product of the array elements
|
310
|
-
# and generate this number of random values.
|
311
|
-
size.reduce(1, :*).times { |i| random_values << rng.rand }
|
312
|
-
end
|
289
|
+
NMatrix.size(shape).times { |i| random_values << rng.rand }
|
313
290
|
|
314
|
-
NMatrix.new(
|
291
|
+
NMatrix.new(shape, random_values, {:dtype => :float64, :stype => :dense}.merge(opts))
|
315
292
|
end
|
316
293
|
|
317
294
|
#
|
318
295
|
# call-seq:
|
319
|
-
# seq(
|
320
|
-
# seq(
|
296
|
+
# seq(shape) -> NMatrix
|
297
|
+
# seq(shape, options) -> NMatrix
|
321
298
|
#
|
322
299
|
# Creates a matrix filled with a sequence of integers starting at zero.
|
323
300
|
#
|
324
301
|
# * *Arguments* :
|
325
|
-
# - +
|
326
|
-
# - +
|
302
|
+
# - +shape+ -> Array (or integer for square matrix) specifying the dimensions.
|
303
|
+
# - +options+ -> (optional) Options permissible for NMatrix#initialize
|
327
304
|
# * *Returns* :
|
328
|
-
# - NMatrix filled with
|
305
|
+
# - NMatrix filled with values 0 through +size+.
|
329
306
|
#
|
330
307
|
# Examples:
|
331
308
|
#
|
332
309
|
# NMatrix.seq(2) # => 0 1
|
333
310
|
# 2 3
|
334
311
|
#
|
335
|
-
# NMatrix.seq([3, 3], :float32) # => 0.0 1.0 2.0
|
312
|
+
# NMatrix.seq([3, 3], dtype: :float32) # => 0.0 1.0 2.0
|
336
313
|
# 3.0 4.0 5.0
|
337
314
|
# 6.0 7.0 8.0
|
338
315
|
#
|
339
|
-
def seq(
|
340
|
-
dtype = params.last.is_a?(Symbol) ? params.pop : nil
|
341
|
-
size = params.first
|
342
|
-
|
343
|
-
# Must provide the dimension as an Integer for a square matrix or as an
|
344
|
-
# 2 element array, e.g. [2,4].
|
345
|
-
unless size.is_a?(Integer) || (size.is_a?(Array) && size.size < 3)
|
346
|
-
raise ArgumentError, "seq() accepts only integers or 2-element arrays \
|
347
|
-
as dimension."
|
348
|
-
end
|
316
|
+
def seq(shape, options={})
|
349
317
|
|
350
318
|
# Construct the values of the final matrix based on the dimension.
|
351
|
-
|
352
|
-
values = (0 .. (size * size - 1)).to_a
|
353
|
-
else
|
354
|
-
# Dimensions given by a 2 element array.
|
355
|
-
values = (0 .. (size.first * size.last - 1)).to_a
|
356
|
-
end
|
319
|
+
values = (0 ... NMatrix.size(shape)).to_a
|
357
320
|
|
358
321
|
# It'll produce :int32, except if a dtype is provided.
|
359
|
-
NMatrix.new(
|
322
|
+
NMatrix.new(shape, values, {:stype => :dense}.merge(options))
|
360
323
|
end
|
361
324
|
|
362
325
|
#
|
363
326
|
# call-seq:
|
364
327
|
# indgen(size) -> NMatrix
|
365
328
|
#
|
366
|
-
# Returns an integer NMatrix. Equivalent to <tt>seq(n, :int32)</tt>.
|
329
|
+
# Returns an integer NMatrix. Equivalent to <tt>seq(n, dtype: :int32)</tt>.
|
367
330
|
#
|
368
331
|
# * *Arguments* :
|
369
|
-
# - +
|
332
|
+
# - +shape+ -> Shape of the sequence.
|
370
333
|
# * *Returns* :
|
371
334
|
# - NMatrix with dtype +:int32+.
|
372
335
|
#
|
373
|
-
def indgen(
|
374
|
-
NMatrix.seq(
|
336
|
+
def indgen(shape)
|
337
|
+
NMatrix.seq(shape, dtype: :int32)
|
375
338
|
end
|
376
339
|
|
377
340
|
#
|
378
341
|
# call-seq:
|
379
|
-
# findgen(
|
342
|
+
# findgen(shape) -> NMatrix
|
380
343
|
#
|
381
|
-
# Returns a float NMatrix. Equivalent to <tt>seq(n, :float32)</tt>.
|
344
|
+
# Returns a float NMatrix. Equivalent to <tt>seq(n, dtype: :float32)</tt>.
|
382
345
|
#
|
383
346
|
# * *Arguments* :
|
384
|
-
# - +
|
347
|
+
# - +shape+ -> Shape of the sequence.
|
385
348
|
# * *Returns* :
|
386
349
|
# - NMatrix with dtype +:float32+.
|
387
350
|
#
|
388
|
-
def findgen(
|
389
|
-
NMatrix.seq(
|
351
|
+
def findgen(shape)
|
352
|
+
NMatrix.seq(shape, dtype: :float32)
|
390
353
|
end
|
391
354
|
|
392
355
|
#
|
393
356
|
# call-seq:
|
394
357
|
# bindgen(size) -> NMatrix
|
395
358
|
#
|
396
|
-
# Returns a byte NMatrix. Equivalent to <tt>seq(n, :byte)</tt>.
|
359
|
+
# Returns a byte NMatrix. Equivalent to <tt>seq(n, dtype: :byte)</tt>.
|
397
360
|
#
|
398
361
|
# * *Arguments* :
|
399
|
-
# - +size+ ->
|
362
|
+
# - +size+ -> Shape of the sequence.
|
400
363
|
# * *Returns* :
|
401
364
|
# - NMatrix with dtype +:byte+.
|
402
365
|
#
|
403
|
-
def bindgen(
|
404
|
-
NMatrix.seq(
|
366
|
+
def bindgen(shape)
|
367
|
+
NMatrix.seq(shape, dtype: :byte)
|
405
368
|
end
|
406
369
|
|
407
370
|
#
|
408
371
|
# call-seq:
|
409
|
-
# cindgen(
|
372
|
+
# cindgen(shape) -> NMatrix
|
410
373
|
#
|
411
|
-
# Returns
|
374
|
+
# Returns a complex NMatrix. Equivalent to <tt>seq(n, dtype: :complex64)</tt>.
|
412
375
|
#
|
413
376
|
# * *Arguments* :
|
414
|
-
# - +
|
377
|
+
# - +shape+ -> Shape of the sequence.
|
415
378
|
# * *Returns* :
|
416
379
|
# - NMatrix with dtype +:complex64+.
|
417
380
|
#
|
418
|
-
def cindgen(
|
419
|
-
NMatrix.seq(
|
381
|
+
def cindgen(shape)
|
382
|
+
NMatrix.seq(shape, dtype: :complex64)
|
420
383
|
end
|
421
384
|
|
422
385
|
end
|
@@ -455,6 +418,8 @@ module NVector
|
|
455
418
|
raise(ArgumentError, "shape must be a Fixnum or an Array of positive Fixnums where exactly one value is 1")
|
456
419
|
end
|
457
420
|
|
421
|
+
warn "NVector is deprecated and not guaranteed to work any longer"
|
422
|
+
|
458
423
|
NMatrix.new(stype, shape, *args)
|
459
424
|
end
|
460
425
|
|
@@ -482,7 +447,7 @@ module NVector
|
|
482
447
|
# 0
|
483
448
|
#
|
484
449
|
def zeros(size, dtype = :float64)
|
485
|
-
|
450
|
+
NMatrix.new([size,1], 0, dtype: dtype)
|
486
451
|
end
|
487
452
|
alias :zeroes :zeros
|
488
453
|
|
@@ -510,7 +475,7 @@ module NVector
|
|
510
475
|
# 1
|
511
476
|
#
|
512
477
|
def ones(size, dtype = :float64)
|
513
|
-
|
478
|
+
NMatrix.new([size,1], 1, dtype: dtype)
|
514
479
|
end
|
515
480
|
|
516
481
|
#
|
@@ -522,7 +487,7 @@ module NVector
|
|
522
487
|
#
|
523
488
|
# * *Arguments* :
|
524
489
|
# - +size+ -> Array (or integer for square matrix) specifying the dimensions.
|
525
|
-
# - +
|
490
|
+
# - +opts+ -> (optional) NMatrix#initialize options
|
526
491
|
# * *Returns* :
|
527
492
|
# - NVector filled with random numbers generated by the +Random+ class.
|
528
493
|
#
|
@@ -531,13 +496,13 @@ module NVector
|
|
531
496
|
# NVector.rand(2) # => 0.4859439730644226
|
532
497
|
# 0.1783195585012436
|
533
498
|
#
|
534
|
-
def random(size)
|
499
|
+
def random(size, opts = {})
|
535
500
|
rng = Random.new
|
536
501
|
|
537
502
|
random_values = []
|
538
503
|
size.times { |i| random_values << rng.rand }
|
539
504
|
|
540
|
-
|
505
|
+
NMatrix.new([size,1], random_values, opts)
|
541
506
|
end
|
542
507
|
|
543
508
|
#
|
@@ -566,7 +531,7 @@ module NVector
|
|
566
531
|
def seq(size, dtype = :int64)
|
567
532
|
values = (0 ... size).to_a
|
568
533
|
|
569
|
-
|
534
|
+
NMatrix.new([size,1], values, dtype: dtype)
|
570
535
|
end
|
571
536
|
|
572
537
|
#
|
@@ -665,8 +630,8 @@ module NVector
|
|
665
630
|
step = (b - a) * (1.0 / (n - 1))
|
666
631
|
|
667
632
|
# dtype = :float64 is used to prevent integer coercion.
|
668
|
-
result = NVector.seq(n, :float64) *
|
669
|
-
result +=
|
633
|
+
result = NVector.seq(n, :float64) * NMatrix.new([n,1], step, dtype: :float64)
|
634
|
+
result += NMatrix.new([n,1], a, dtype: :float64)
|
670
635
|
result
|
671
636
|
end
|
672
637
|
|