diff options
author | Marc-Andre Lafortune <[email protected]> | 2020-04-30 17:04:46 -0400 |
---|---|---|
committer | Marc-Andre Lafortune <[email protected]> | 2020-05-01 03:25:13 -0400 |
commit | 07fd6dc49ba87ea2f0732851ec7628a526f3dcbd (patch) | |
tree | 0589852096ee32b02902b8d386acf7a969a4f9e8 /lib/matrix.rb | |
parent | 3cb038cc7a9b1e01685a7e8a513e7ac7fb56b112 (diff) |
[ruby/matrix] Optimize Matrix#*
Diffstat (limited to 'lib/matrix.rb')
-rw-r--r-- | lib/matrix.rb | 22 |
1 files changed, 12 insertions, 10 deletions
diff --git a/lib/matrix.rb b/lib/matrix.rb index 7d35b61fc5..75b5da29c7 100644 --- a/lib/matrix.rb +++ b/lib/matrix.rb @@ -1057,25 +1057,27 @@ class Matrix def *(m) # m is matrix or vector or number case(m) when Numeric - rows = @rows.collect {|row| + new_rows = @rows.collect {|row| row.collect {|e| e * m } } - return new_matrix rows, column_count + return new_matrix new_rows, column_count when Vector m = self.class.column_vector(m) r = self * m return r.column(0) when Matrix raise ErrDimensionMismatch if column_count != m.row_count - - rows = Array.new(row_count) {|i| - Array.new(m.column_count) {|j| - (0 ... column_count).inject(0) do |vij, k| - vij + self[i, k] * m[k, j] + m_rows = m.rows + new_rows = rows.map do |row_i| + Array.new(m.column_count) do |j| + vij = 0 + column_count.times do |k| + vij += row_i[k] * m_rows[k][j] end - } - } - return new_matrix rows, m.column_count + vij + end + end + return new_matrix new_rows, m.column_count else return apply_through_coercion(m, __method__) end |